请求服务器异常:JSON parse error: Unexpected end-of-input: was expecting closing ‘“‘ for name; nested excep

@[TOC](请求服务器异常:JSON parse error: Unexpected end-of-input: was expecting closing ‘"’ for name; nested exception is … ‘"’ for name at [Source: (PushbackInputStream); line: 1, column: 5]))

问题起因:EMQX 4.0.5 WebHook BUG

开发调试EMQX 4.0.5 WebHook功能时发现当payload长度大于一定字符数时WebHook接收方接收请求参数异常 HttpStatus 400 错误。

JSON 解析异常

JSON parse error: Unexpected end-of-input: was expecting 
closing '"' for name; nested exception is com.fasterxml.jackson.core.io.JsonEOFException: Unexpected end-of-input: was expecting closing '"' for name
 at [Source: (PushbackInputStream); line: 1, column: 5]

服务端日志打印信息,此段信息表明请求方请求参数无法被JSON解析。JSON信息不完整。

原因

POST请求方即EMQX broker,请求POST接口时 header 中 content-length 长度与实际请求长度不一致 导致请求的JSON信息不完整。

在这里插入图片描述

此处用到Linux 抓包工具 tcpdump

查看HTTP POST请求

tcpdump -s 0 -A 'tcp dst port 80 and (tcp[((tcp[12:1] & 0xf0) >> 2):4] = 0x504f5354)'

EMQX broker 在4.1 版本已解决此问题
与此问题类似的 issue:

https://github.com/emqx/emqx/issues/3382

解决方案

更新4.1以上版本

JSON parse error: Unexpected end-of-input in field name 这个错误通常出现在解析JSON数据时,表示在字段名结束时遇到了意外的输入结束。这可能是因为JSON字符串不完整或格式不正确。以下是一些常见的解决方法: 1. **检查JSON字符串的完整性**: 确保JSON字符串的括号、大括号和引号都是成对出现的,并且没有遗漏。例如,JSON对象应该以`{}`结束,数组应该以`[]`结束。 2. **验证JSON格式**: 使用在线工具如 [JSONLint](https://jsonlint.com/) 来验证JSON字符串的格式是否正确。 3. **检查数据源**: 如果JSON数据是从外部源获取的,确保数据源返回的数据是完整的和正确的。 4. **处理网络请求**: 如果JSON数据是通过网络请求获取的,确保在数据完全接收后再进行解析。可以在网络请求的回调函数中处理数据。 5. **调试日志**: 打印出完整的JSON字符串,查看是否在预期的位置结束。 以下是一个示例代码,展示了如何处理网络请求并在数据完全接收后进行解析: ```python import json import requests def fetch_json(url): try: response = requests.get(url) response.raise_for_status() # 检查请求是否成功 data = response.text json_data = json.loads(data) return json_data except requests.exceptions.RequestException as e: print(f"网络请求错误: {e}") except json.JSONDecodeError as e: print(f"JSON解析错误: {e}") url = "http://example.com/data.json" json_data = fetch_json(url) if json_data: print(json_data) ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值