1. 相关技术

  • springboot 2.6.3
  • mybatis-spring-boot-starter 2.2.2
  • mybatis 3.5.10
  • fastjson 1.2.83
  • hutool-all 5.7.22
  • shiro-spring 1.8.0

2. 报错信息

“write javaBean error, fastjson version 1.2.83, class org.apache.shiro.web.servlet.ShiroHttpServletRequest, method : getAsyncContext”

具体信息,如下:

3. 报错原因

ShiroHttpServletRequest不能被fastjson1.2.83序列化。序列化对象key带下划线、特殊符号等等, 都有可能。

4. 部分具体代码

import com.alibaba.fastjson.JSON

Object[] requestParams = pjp.getArgs();StringBuffer sb = new StringBuffer();for (Object requestParam : requestParams) {    if (requestParam != null) {        sb.append(JSON.toJSONString(requestParam)); // 报错代码        sb.append(",");    }}

5. 解决方案

方案一:

使用hutool的Json工具类,如下

sb.append(JSONUtil.toJsonStr(requestParam))

方案二:

在 toJSONString 调用过程中加入 SerializerFeature.IgnoreErrorGetter,如下

sb.append(JSON.toJSONString(requestParam, SerializerFeature.IgnoreErrorGetter));

方案三:

在字段上添加注解 @JSONField(serialize =false), 这样做不会报错可以顺利打印,但是添加该注解的字段将不会被序列化并放入到json字符串中。(注意:这里不可取,ShiroHttpServletRequest属于shiro相关依赖的内部类。推荐前两种