POST请求报错

博客内容讲述了在处理请求参数时遇到的一个不寻常问题,即JSON解析错误并非由于常见的逗号、缺少双引号或冒号的中英文错误,而是由于参数前的长空格导致。这个问题在Postman中通过删除空格得到了解决,强调了细节检查的重要性。

请求参数

{
    "userId": 2,
    "shipState": null
}

报错:
{
“message”: “JSON parse error: Unexpected character (’ ’ (code 160)): was expecting double-quote to start field name; nested exception is com.fasterxml.jackson.core.JsonParseException: Unexpected character (’ ’ (code 160)): was expecting double-quote to start field name\n at [Source: (PushbackInputStream); line: 2, column: 3]”
}

本次原因:
不是因为逗号,不是因为有的数据没加双引号,也不是冒号中英文错误。
是参数前面的空格 (破防了啊家人们,被空格阻挡)
在这里插入图片描述
就是这前面的空格,因为直接复制的别人给我的参数,复制过的空格比较长,一个顶两个postman里的空格 把空格删掉,直接打空格就可解决。

POST请求报错415(Unsupported Media Type)通常是因为服务器不支持客户端发送的请求体类型。以下是不同场景下的解决办法: ### 原生Ajax请求 在原生Ajax的POST请求中,若未正确设置`contentType`会报415错误。需要确保请求头的`Content-Type`与发送的数据格式匹配。例如,若发送的数据是表单格式,应设置请求头为`application/x-www-form-urlencoded`: ```javascript let btn = document.querySelector('button'); let p = document.querySelector('p'); btn.addEventListener('click', function () { let xhr = new XMLHttpRequest(); xhr.open('post', 'http://139.9.177.51:3333/api/testPost'); // 设置请求头 xhr.setRequestHeader('Content-Type', 'application/x-www-form-urlencoded'); xhr.send('name=张三'); xhr.onreadystatechange = function () { if (xhr.readyState === 4 && xhr.status === 200) { let data = JSON.parse(xhr.responseText); console.log(data); p.innerHTML = data['data']; } } }); ``` 若发送的是JSON数据,则应设置`Content-Type`为`application/json`,并将数据转换为JSON字符串发送: ```javascript let data = { name: '张三' }; xhr.setRequestHeader('Content-Type', 'application/json'); xhr.send(JSON.stringify(data)); ``` ### SpringBoot项目 在SpringBoot中使用`@RequestBody`接收参数时,要确保客户端发送的是合法的JSON数据。若请求头的`Content-Type`不是`application/json`,服务器可能无法正确解析请求体,从而报415错误。可以在客户端设置请求头`Content-Type`为`application/json`,并将数据转换为JSON字符串发送。例如使用`RestTemplate`发送请求时: ```java import org.springframework.http.*; import org.springframework.web.client.RestTemplate; import java.util.LinkedMultiValueMap; import java.util.Map; public class Test { private RestTemplate restTemplate; public void show() { HttpHeaders httpHeaders = new HttpHeaders(); httpHeaders.add("accept", MediaType.APPLICATION_JSON_UTF8_VALUE); httpHeaders.setContentType(MediaType.APPLICATION_JSON_UTF8); // 假设这里是请求体数据 Map<String, Object> param = Map.of("key", "value"); HttpEntity<Map<String, Object>> httpEntity = new HttpEntity<>(param, httpHeaders); restTemplate.postForEntity(url, httpEntity, String.class); } } ``` ### RestTemplate发送请求 使用`RestTemplate`发送POST请求时,要确保请求头的`Content-Type`与请求接口的`consumes`属性匹配。例如: ```java import org.springframework.http.*; import org.springframework.web.client.RestTemplate; import java.util.LinkedMultiValueMap; import java.util.Map; public class Test { @Autowired private RestTemplate restTemplate; public void show() { HttpHeaders httpHeaders = new HttpHeaders(); httpHeaders.add("accept", MediaType.APPLICATION_JSON_UTF8_VALUE); httpHeaders.setContentType(MediaType.APPLICATION_JSON_UTF8); // 创建请求体 LinkedMultiValueMap<String, Object> multiValueMap = new LinkedMultiValueMap<>(); multiValueMap.add("key", "value"); HttpEntity<LinkedMultiValueMap<String, Object>> httpEntity = new HttpEntity<>(multiValueMap, httpHeaders); restTemplate.postForEntity(url, httpEntity, String.class); } } ``` ### Yii框架 在Yii框架中,若POST请求报415错误,可能与CSRF验证有关。可以通过关闭CSRF验证或在表单中加入隐藏域来解决。关闭CSRF验证的方法如下: ```php public function init() { $this->enableCsrfValidation = false; } ``` 或者在类中直接设置: ```php public $enableCsrfValidation = false; ``` 若是表单POST请求,在表单中加入隐藏域: ```html <input name="_csrf" type="hidden" id="_csrf" value="<?= \Yii::$app->request->csrfToken ?>"> ```
评论 1
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值