fastjson报java.lang.ArrayIndexOutOfBoundsException: 160

女爷i 2022-05-15 02:54 336阅读 0赞

今天线上遇到一个问题,从hbase里读取出来的数据在转换json后输出时出现异常:

  1. java.lang.ArrayIndexOutOfBoundsException: 160
  2. at com.alibaba.fastjson.serializer.SerializeWriter.writeStringWithDoubleQuote(SerializeWriter.java:868)
  3. at com.alibaba.fastjson.serializer.SerializeWriter.writeStringWithDoubleQuote(SerializeWriter.java:602)
  4. at com.alibaba.fastjson.serializer.SerializeWriter.writeString(SerializeWriter.java:1411)
  5. at com.alibaba.fastjson.serializer.StringCodec.write(StringCodec.java:49)
  6. at com.alibaba.fastjson.serializer.StringCodec.write(StringCodec.java:34)
  7. at com.alibaba.fastjson.serializer.MapSerializer.write(MapSerializer.java:188)
  8. at com.alibaba.fastjson.serializer.ListSerializer.write(ListSerializer.java:158)
  9. at com.alibaba.fastjson.serializer.MapSerializer.write(MapSerializer.java:188)
  10. at com.alibaba.fastjson.serializer.JSONSerializer.write(JSONSerializer.java:369)
  11. at com.alibaba.fastjson.JSON.toJSONString(JSON.java:596)
  12. at com.alibaba.fastjson.JSON.toString(JSON.java:590)
  13. at java.lang.String.valueOf(String.java:2854)
  14. at java.io.PrintStream.println(PrintStream.java:821)

从异常信息中可以看出是在json toString的时候出现了错误,可能是引号或者其它不可见字符导致的,查看实际数据并没有出现单双引号,但是出现了\t\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0,\t是不应该出现问题的,那问题就只可能是\u00A0 导致的,查看UNICODE对照表,发现\u00A0确实是一个不可见字符

(unicode 对照表:https://unicode-table.com/en/#control-character):

813613-20170424193540053-1199823516.png

\u00A0转ASCII,正好是160

813613-20170424193406084-1336907292.png

问题变得简单了,可能是fastjson 对不可见字符的支持问题,于是换了个最新版试一下,果然一切正常,问题是解决了,但是得找到具体原因,看了看源代码,当前使用的这个

版本(1.1.39以及1.1.39以下版本) 确实有部分特殊字符未做处理。

解决:将fastjson-1.1.39.jar升级到fastjson-1.2.47.jar 问题解决

可参考官方修正提交:https://github.com/alibaba/fastjson/commit/cdf7cb253e961666e2b3c2bdd423abe73ba4324a#diff-0

文章来源:https://www.cnblogs.com/jessezeng/p/6758569.html

发表评论

表情:
评论列表 (有 0 条评论,336人围观)

还没有评论,来说两句吧...

相关阅读

    相关 160小时

    昨天好像学了不少东西,可是回过头来看,好像又啥也没学,还是记录一下吧: [如何编写一个插件][Link 1] [Vue项目基本优化][Vue] 回顾图片懒加

    相关 LeetCode 160

    问题描述: 编写一个程序,找到两个单链表相交的起始节点。 如下面的两个链表: 在节点 c1 开始相交。   示例 1: 输入:intersectVal = 8, l