字符串JSON转换异常:cn.hutool.json.JSONException: Mismatched hr and body

报错起因:

1、在调用外部api接口,获取JSON字符串,通过各种JSON文件转对象的时候发现报错。

String post = HttpUtil.post(url, JSONUtil.toJsonStr(params));
JSONObject jsonObject = JSONUtil.parseObj(post);

报错信息如下:

cn.hutool.json.JSONException: Mismatched hr and body at 164 [character 6 line 6]
	at cn.hutool.json.JSONTokener.syntaxError(JSONTokener.java:413)
	at cn.hutool.json.xml.JSONXMLParser.parse(JSONXMLParser.java:99)
	at cn.hutool.json.xml.JSONXMLParser.parse(JSONXMLParser.java:164)
	at cn.hutool.json.xml.JSONXMLParser.parse(JSONXMLParser.java:164)
	at cn.hutool.json.xml.JSONXMLParser.parse(JSONXMLParser.java:164)
	at cn.hutool.json.xml.JSONXMLParser.parseJSONObject(JSONXMLParser.java:29)
	at cn.hutool.json.XML.toJSONObject(XML.java:101)
	at cn.hutool.json.ObjectMapper.mapFromStr(ObjectMapper.java:216)
	at cn.hutool.json.ObjectMapper.map(ObjectMapper.java:98)
	at cn.hutool.json.JSONObject.<init>(JSONObject.java:210)
	at cn.hutool.json.JSONObject.<init>(JSONObject.java:187)
	at cn.hutool.json.JSONObject.<init>(JSONObject.java:142)
	at cn.hutool.json.JSONObject.<init>(JSONObject.java:125)
	at cn.hutool.json.JSONUtil.parseObj(JSONUtil.java:88)

排查过程:

一开始,我一直以为是因为hutool 工具,或者其他JSON有转换的异常,百度,谷歌很多方案,只提示了问题是xml转body错误。
一般这种问题还是要看你转换报错信息,最好给日志打印出来,后来通过try,catch,以及日志打印异常,最终知道报错原因:

<html>
<head><title>504 Gateway Time-out</title></head>
<body bgcolor="white">
<center><h1>504 Gateway Time-out</h1></center>
<hr><center>nginx</center>
</body>
</html>
<!-- a padding to disable MSIE and Chrome friendly error page -->
<!-- a padding to disable MSIE and Chrome friendly error page -->
<!-- a padding to disable MSIE and Chrome friendly error page -->
<!-- a padding to disable MSIE and Chrome friendly error page -->
<!-- a padding to disable MSIE and Chrome friendly error page -->
<!-- a padding to disable MSIE and Chrome friendly error page -->

总结: 问题出现在http请求外部接口的时候,有时候,可能存在网络抖动,后者过于频繁的请求接口,导致接口偶发性的出现504网络异常。导致自己需要查找的数据没有查找到,或者解析出来。

最终解决办法:

通过重试机制,三次延时调用接口,提高对调用接口这种偶发性的问题的解决方案。

		JSONObject jsonObject = null;
        int count = 0;
        while (count < 3) {
            try {
                String post = HttpUtil.post("url", JSONUtil.toJsonStr(params));
                jsonObject = JSONUtil.parseObj(post);
                count = 3;
            } catch (Exception e) {
                log.error("JSON异常:{}", e.getMessage());
                count++;
                try {
                    log.warn("=============第{}次等待{}秒后重新请求接口=============", count, 5 * count);
                    Thread.sleep(5000 * count);
                } catch (InterruptedException interruptedException) {
                    interruptedException.printStackTrace();
                }
            }
        }

以上是个人的关于JSON转换异常的问题总结:如果异议,欢迎在评论提出疑问,共同进步!

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
根据你提供的信息,这个异常是由于在使用 `net.sf.json` 库的 JSON 转换过程中,尝试将一个无法格式化为日期的对象作为日期进行格式化。 `java.lang.IllegalArgumentException: Cannot format given Object as a Date` 异常表示给定的对象无法被格式化为日期。 可能的原因和解决方法如下: 1. 对象类型不正确:确保要格式化的对象是 `java.util.Date` 或其子类的实例。如果对象不是日期类型,尝试将其转换为正确的日期类型。 2. 日期格式不正确:检查传入的对象是否符合日期格式的要求。日期格式可能包括年、月、日、时、分、秒等组成部分,如果传入的对象无法满足格式要求,将会引发异常。确保对象的值和格式是符合预期的。 3. 日期格式化器配置错误:在进行日期格式化时,可能会使用 `SimpleDateFormat` 或其他日期格式化器。请确保在配置日期格式化器时,使用正确的日期格式模式,并且与要格式化的对象类型相匹配。 以下是一个示例,演示如何使用 `SimpleDateFormat` 格式化日期对象: ```java import net.sf.json.JsonConfig; import net.sf.json.processors.JsonValueProcessor; import java.text.SimpleDateFormat; import java.util.Date; public class DateTimeJsonValueProcessor implements JsonValueProcessor { private static final String DATE_PATTERN = "yyyy-MM-dd"; @Override public Object processArrayValue(Object value, JsonConfig jsonConfig) { return process(value); } @Override public Object processObjectValue(String key, Object value, JsonConfig jsonConfig) { return process(value); } private Object process(Object value) { if (value instanceof Date) { SimpleDateFormat dateFormat = new SimpleDateFormat(DATE_PATTERN); return dateFormat.format((Date) value); } return null; } } ``` 在上述示例中,我们使用 `SimpleDateFormat` 将日期对象格式化为指定的日期格式。你可以根据自己的需求修改日期格式模式。 确保在使用 `net.sf.json` 进行 JSON 转换时,注册自定义的值处理器,并正确配置日期格式化器。 根据具体的情况,你可能需要仔细检查代码,并根据堆栈跟踪中提供的更详细信息,进一步分析和调试以找出导致异常的确切原因,并采取适当的措施来解决问题。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值