场景
在调用别人接口时返回的token如下:
{
"token": "eyJ0eeqOiJKV1QiL/CJhbGciOiJIUzI1NiJ9.eyJhdWQiOiJhZj\FjMTU1O#TFmZTAxMWViOGR(lMTAyNDwNSI_sImV4cCI6M=TYxMDMzMj\UzMX0.ODtsPyUnfv6Qh_dOWTfSj416Y"
}
返回来的字符串里什么特殊符号都有,彼时项目中使用的是GSON,解析字符串时解析到反斜杠\
时直接报错,返回一番搜寻后,使用了fastjson来对字符串进行解析,最后直接成功,但是在别人的推荐下(fastjson自身存在许多高危漏洞,在对安全性有要求的系统中不建议使用),我就转用Jackson来进行解析了。
解决方案
代码:
JsonMapper objectMapper = JsonMapper.builder().enable(ALLOW_BACKSLASH_ESCAPING_ANY_CHARACTER).build();
JsonNode jsonNode = objectMapper.readValue(jsonStr, JsonNode.class);
执行结果:
思路分析
其实在这里主要还是通过开启ALLOW_BACKSLASH_ESCAPING_ANY_CHARACTER
属性允许这种不标准的json串解析。
通过使用开启后的ObjectMapper
对象完成相关的字符解析操作。
这里当然要提供大佬原本的参考链接:http://www.zhyea.com/2020/10/22/how-to-deal-with-backslash-with-jackson.html