post请求返回400错误但是postman却调用成功
遇到一个很奇怪的问题,做一个http调用其他系统api的功能,代码写完后在本地测试一切正常,但是部署到服务器后post请求全部都400错误了
怀疑是参数格式错了,然后在日志里面把URL和参数复制出来在postman中调用测试,发现居然成功调用
然后以为请求工具类有问题,又在本地跑起来一遍,发现又是一切正常,那么代码应该没有问题才对
因为postman成功了所以地址和参数应该也没有问题,那么测试后也发现参数只有格式错了才会返回400错误
那么也就是说我的参数在发送之后被改变了格式,(一番折腾后)最后讲视线放在了Tomcat上面,查找资料的过程中得知Tomcat的属性里面有一个MaxPostSize属性,这个属性设置为-1就可以了,他的作用就是限制post请求的参数大小,-1是不限制大小,如果没有自己添加一下
在conf/server.xml 文件中,在 标签中设置 maxPostSize="-1"
后来发现上面那个方法是错误的
正确的是换一个http工具类,用HTTPclient这种方式,代码如下,token可以自己换掉
import java.io.IOException;
import org.apache.http.HttpEntity;
import org.apache.http.client.ClientProtocolException;
import org.apache.http.client.config.RequestConfig;
import org.apache.http.client.entity.UrlEncodedFormEntity;
import org.apache.http.client.methods.CloseableHttpResponse;
import org.apache.http.client.methods.HttpDelete;
import org.apache.http.client.methods.HttpGet;
import org.apache.http.client.methods.HttpPost;
import org.apache.http.client.methods.HttpPut;
import org.apache.http.entity.StringEntity;
import org.apache.http.impl.client.CloseableHttpClient;
import org.apache.http.impl.client.HttpClients;
import org.apache.http.util.EntityUtils;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
public class HttpUtil {
private static final Logger log = LoggerFactory.getLogger(HttpUtil.class);
/**
* 原生字符串发送get请求
*
* @param url
* @return
* @throws IOException
* @throws
*/
public static String doGet(String url, String token) {
log.info("url:"+url);
CloseableHttpClient httpClient = HttpClients.createDefault();
HttpGet httpGet = new HttpGet(url);
httpGet.setHeader("Content-type", "application/json");
httpGet.setHeader("DataEncoding", "UTF-8");
httpGet.setHeader("token", token);
RequestConfig requestConfig = RequestConfig.custom().setConnectTimeout(35000).setConnectionRequestTimeout(35000).setSocketTimeout(60000).build();
httpGet.setConfig(requestConfig);
CloseableHttpResponse httpResponse = null;
try {
httpResponse = httpClient.execute(httpGet);
HttpEntity entity = httpResponse.getEntity();