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相关依赖的内部类。推荐前两种)