博客
关于我
来啊踩fastjson打印入参导致业务跑偏的坑
阅读量:489 次
发布时间:2019-03-06

本文共 643 字,大约阅读时间需要 2 分钟。

在使用Spring AOP切面进行日志记录时,若遇到JSONObject.toJSONString(pjp.getArgs())抛出IllegalStateException,提示“当前请求不在异步模式中”,可以按照以下步骤进行排查和解决:

  • 检查日志切面中的参数类型:首先,确认pj.getArgs()中的参数类型是否包含不支持FastJSON序列化的对象,如某些自定义对象或特殊类型。确保所有参数均可被FastJSON正常处理。

  • 审查业务逻辑:检查业务方法中是否存在潜在的异常情况,例如未捕获的异常或状态不一致,导致切面在非异步请求中执行了不允许的操作。

  • 分析FastJSON序列化过程:深入查看FastJSON源码,特别是writeWithFieldNamewrite方法,确认是否在处理特定类型(如集合、数组或自定义对象)时遇到问题。注意动态生成的ASM代码部分是否有错误。

  • 调整序列化配置:尝试通过配置SerializerFeature来调整序列化行为,例如禁用某些特性或设置合适的日期格式,避免不必要的复杂处理。

  • 测试和验证:在非生产环境中模拟不同场景,验证日志记录是否正常工作。确保切面仅在需要时启用,以减少潜在问题。

  • 参考解决方案:查阅类似问题的解决方法,例如是否有其他开发者遇到过类似的IllegalStateException,并参考他们的修复方案。

  • 通过以上步骤,可以系统地定位并解决FastJSON在切面日志记录中的问题,确保业务代码的稳定性和日志记录的有效性。

    转载地址:http://jblbz.baihongyu.com/

    你可能感兴趣的文章
    SQL-36 创建一个actor_name表,将actor表中的所有first_name以及last_name导入改表。
    查看>>
    ORM sqlachemy学习
    查看>>
    orm总结
    查看>>
    os.path.join、dirname、splitext、split、makedirs、getcwd、listdir、sep等的用法
    查看>>
    os.system 在 Python 中不起作用
    查看>>
    OSCACHE介绍
    查看>>
    SQL--合计函数(Aggregate functions):avg,count,first,last,max,min,sum
    查看>>
    OSChina 周五乱弹 ——吹牛扯淡的耽误你们学习进步了
    查看>>
    OSChina 周四乱弹 ——程序员为啥要买苹果手机啊?
    查看>>
    OSError: no library called “cairo-2“ was foundno library called “cairo“ was foundno library called
    查看>>
    Osgi环境配置
    查看>>
    OSG学习:几何体的操作(二)——交互事件、Delaunay三角网绘制
    查看>>
    OSG学习:几何对象的绘制(三)——几何元素的存储和几何体的绘制方法
    查看>>
    OSG学习:几何对象的绘制(二)——简易房屋
    查看>>
    OSG学习:场景图形管理(一)——视图与相机
    查看>>
    OSG学习:场景图形管理(三)——多视图相机渲染
    查看>>
    OSG学习:场景图形管理(二)——单窗口多相机渲染
    查看>>
    OSG学习:场景图形管理(四)——多视图多窗口渲染
    查看>>
    OSG学习:新建C++/CLI工程并读取模型(C++/CLI)——根据OSG官方示例代码初步理解其方法
    查看>>
    Sql 随机更新一条数据返回更新数据的ID编号
    查看>>