使用@Profiled注解或自定义AOP拦截打印日志json序列化失败

使用@Profiled注解或自定义AOP拦截打印日志json序列化失败项目中使用@Profiled注解方式进行统一日志打印输出fastjson踩坑记录一下1:@Profiled注解方式如上图:方法上使用注解@Profiled,因为我的入参有HttpServletResponse,日志打印时会对所有入参进行序列化操作,所对以HttpServletResponse进行JSON.toJSONString()转换会抛出以上异常,此时要么干掉HttpServletResponse,或者换一种方式手动注入HttpServletResponse即可解决以上异常,如下图:

大家好,又见面了,我是你们的朋友全栈君。

项目中使用@Profiled注解方式进行统一日志打印输出fastjson踩坑记录一下

1:@Profiled注解方式

使用@Profiled注解或自定义AOP拦截打印日志json序列化失败

使用@Profiled注解或自定义AOP拦截打印日志json序列化失败

如上图:

方法上使用注解@Profiled,因为我的入参有HttpServletResponse,日志打印时会对所有入参进行序列化操作,所对以HttpServletResponse进行JSON.toJSONString()转换会抛出以上异常,此时要么干掉HttpServletResponse,或者换一种方式手动注入HttpServletResponse即可解决以上异常,如下图:

ServletRequest,ServletResponse,MultipartFile 不能被序列化

使用@Profiled注解或自定义AOP拦截打印日志json序列化失败

2:自定义AOP拦截打印日志方式

Object[] args = joinPoint.getArgs();

获取入参的时候,args还包含了一些其他的内容,比如ServletReques,ServletResponset等,而这些入参并不能进行序列化,所以JSON.toJSONString时会抛出异常。

解决方法就是过滤掉args里不能被序列化的参数,如下:

Object[] args = joinPoint.getArgs();
        Object[] newArgs  = new Object[args.length];
        for (int i = 0; i < args.length; i++) {
            if (args[i] instanceof ServletRequest || args[i] instanceof ServletResponse || args[i] instanceof MultipartFile) {
                //ServletRequest 、ServletResponse 、 MultipartFile不能序列化,从入参里排除,否则报异常
                continue;
            }
            newArgs[i] = args[i];
        }
        String paramter = "";
        if (newArgs != null) {
            try {
                paramter = JSONObject.toJSONString(newArgs);
            } catch (Exception e) {
                paramter = newArgs.toString();
            }
        }
        logger.info("请求开始{" + logId + "}:clazzName: " + clazzName + ", methodName:" + methodName + ", 参数:" + paramter);

 

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/134567.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • frp内网透传以及连接frp服务器

    frp内网透传以及连接frp服务器frp 服务器实操一 准备工作二 启动三 Socket 工具创建 TCP 服务器四 创建与连接 1 创建 TCPsocket2 连接 TPC 服务器一 准备工作下载 打开 再切换至该应用的路径下二 启动运行 sunny execlientid 隧道 id 三 Socket 工具创建 TCP 服务器切记这个上面设置的这个端口号 6001 要和你隧道管理界面上的本地端口号一致 本人因为没有注意 导致弄了很长的时间 四 创建与连接 1 创建 TCPsocketAT NSOCR STREAM 6

    2025年10月14日
    3
  • 微信小程序开发入门教程

    微信小程序开发入门教程做任何程序开发要首先找到其官方文档,我们先来看看其有哪些官方文档。微信小程序开发文档链接为:https://mp.weixin.qq.com/debug/wxadoc/dev/index.html,如下图:  这里就是做微信小程序开发的全部官方文档。知道了文档的位置,下面我们来介绍下如何做一个微信小程序开发: /***************

    2022年6月5日
    38
  • 魔兽世界WOW服务器端的模拟器【2010】[通俗易懂]

    记不清从什么时候开始,国内出现了很多所谓的魔兽世界私服网站,而且在淘宝上还有什么魔兽世界单机版在出售,其实这些东西都是利用国外的一些开源软件如MaNGOS和ArcEmu来实现的。一、MaNGOS http://getmangos.com/MaNGOS不是一个魔兽私服模拟器(wowemu),它是一个开源的自由软件项目,是用c++和C#编程语言实现的一个支持大型多人在线角色扮演游戏服务

    2022年4月15日
    265
  • wangeditor富文本编辑器的使用(超详细)

    wangeditor富文本编辑器的使用(超详细)wangeditor是一款轻便的富文本编辑器,本文主要帮助大家快速学习使用wangeditor编辑器。

    2022年6月1日
    97
  • 串口助手(简洁版)上位机软件零基础教程( C# + visual studio2017 )(一)[通俗易懂]

    串口助手(简洁版)上位机软件零基础教程( C# + visual studio2017 )(一)[通俗易懂]本人所在铁人战队的实验室同学们主要从事单片机的编程开发。但比赛和项目过程中,常常都需要与机器人进行人机交互。虽然实验室常用的HMI串口屏能满足我们的基本需求,但没东西在手的时候,就是个难题了。所以本文则介绍一下使用visualstudio软件,进行C#上位机软件的开发入门。以同学们常用的串口助手(简洁版)为例,来着手进行学习和入门。由于笔者知识有限,且是第一次写博客,有不足或错误之处,还…

    2022年5月31日
    47
  • Activexobject_javascript打开新窗口

    Activexobject_javascript打开新窗口一、功能实现核心:FileSystemObject对象    要在javascript中实现文件操作功能,主要就是依靠FileSystemobject对象。二、FileSystemObject编程 使用FileSystemObject对象进行编程很简单,一般要经过如下的步骤:创建FileSystemObject对象、应用相关方法、访问对象相关属性。 (一)创建Fi

    2022年10月14日
    3

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号