今天在测试httpclient的post请求时,报了以下错误:
使用Editpus打开之后,如下:
出乎意料,先上代码看下,我的测试代码是这么写的:
@Test
public void doPost() throws Exception {
CloseableHttpClient httpClient = HttpClients.createDefault();
//创建一个post对象
HttpPost post = new HttpPost(“http://localhost:8082/httpclient/post.html“);
post.setHeader(“/”,”application/json”);
CloseableHttpResponse response = httpClient.execute(post);
String result = EntityUtils.toString(response.getEntity(),”utf-8”);
System.out.println(result);
}
调用的服务如下:
@RequestMapping(value= “/httpclient/post”,method = RequestMethod.POST)
@ResponseBody
public TaotaoResult testHttpClient() {
return TaotaoResult.ok();
}
百度了一效,原来错误是这样子的:
NotAcceptable 等效于 HTTP 状态 406。NotAcceptable 指示客户端已用 Accept 头指示将不接受资源的任何可用表示形式。
也就是说以@ResponseBody返回的json数据,在httpclient客户端不识别,仔细观察:发现项目中解析json的包也是没有问题的,如下:
百度最佳答案解释的特别详细:
HTTP 406 指浏览器不接受所请求页面的 MIME 类型
问题在header中Accept 中。并不是所有的服务器接收json都会在response中指定Content-Type为 application/json的,大多数时候大家用的都是 application/xml,如果服务器回来的相应Content-Type为 application/xml,而你把你请求的Accept指定为application/json 的话就会收到错误406. 把Accept 改成/ 允许所有类型再试就好了。
照了试了试没有作用,还是报错,暂时想到的解决的方案是,将返回的具体的bean类改为string,返回个“OK”字符串,临时解决了问题,后续还要做研究,争取能够彻底解决这个问题。
临时修改代码如下:
@RequestMapping(value= “/httpclient/post”,method = RequestMethod.POST)
@ResponseBody
public String testHttpClient() {
return “ok”;
}