前后端JSON数据交互异常及解决方案
问题:后端接口使用@RequestBody接收前端JSON数据时,报错Cannot deserialize instance of java.lang.String out of START_ARRAY token。
问题根源
错误提示表明,后端期望接收一个数组(START_ARRAY token),但实际收到的是一个字符串(java.lang.String)。这通常是因为前端发送的JSON数据格式与后端期望的格式不一致。例如,后端定义了一个List类型的属性,但前端却发送了一个该类型对象的JSON字符串表示,而不是一个JSON数组。
解决方案
解决方法主要有两种:调整前端数据格式或修改后端代码进行数据处理。
List,前端JSON数据应如下所示(示例):{
"isapp": "forandroid",
"taskname": "test",
"pathlist": [
{
"createtime": "2025-07-13 16:34:32",
"cycleindex": "1",
"id": "347",
"maxormin": [
{"latitude": 30, "longitude": 120},
{"latitude": 30, "longitude": 120}
],
"pathname": "test1",
"pathtype": "1",
"pointlist": [
{"latitude": 30, "longitude": 120},
{"latitude": 30, "longitude": 120}
]
},
{ /* ... other HkboatTaskPath objects ... */ }
]
}
@PostMapping("/api/endpoint")
public ResponseEntity handleRequest(@RequestBody String jsonDa
ta) throws JsonProcessingException {
ObjectMapper objectMapper = new ObjectMapper();
JsonNode rootNode = objectMapper.readTree(jsonData);
JsonNode pathList = rootNode.get("pathlist");
List paths = objectMapper.readValue(pathList.toString(), new TypeReference>() {});
// ... further processing of 'paths' ...
return ResponseEntity.ok().build();
}
预防措施
为了避免此类问题再次发生,建议:
通过以上方法,可以有效解决Cannot deserialize instance of java.lang.String out of START_ARRAY token错误,并预防此类问题的再次发生。