Using getResponseBodyAsStream instead is recommended

在用httpClient时,tomcat的控制台报出以下警告。

2018-09-17 14:25:01,447  WARN (org.apache.commons.httpclient.HttpMethodBase:682) - Going to buffer response body of large or unknown size. Using getResponseBodyAsStream instead is recommended.

查看代码,在用httpclient做请求时,用的是String respStr = method.getResponseBodyAsString()

查看getResponseBodyAsString()源代码

报WARN的条件是((contentLength == -1) || (contentLength> limit)),也就是说,或者是返回的HTTP头没有指定contentLength,或者是contentLength大于上限(默认是1M)。如果能确定返回结果的大小对程序没有显著影响,这个WARN就可以忽略,可以在日志的配置中把HttpClient的日志级别调到ERROR,不让它报出来。

当然,这个警告也是有意义的,HttpClient建议使用InputStream getResponseBodyAsStream()代替byte[]getResponseBody()。对于返回结果很大或无法预知的情况,就需要使用InputStreamgetResponseBodyAsStream(),避免byte[] getResponseBody()可能带来的内存的耗尽问题。 部署到tomcat之后,tomcat和redis多次挂掉。原因就是内存耗尽。

如果返回的头信息没有指定长度或长度大于1M则抛出如上异常。
则需把 getResponseBodyAsString()换成 getResponseBodyAsStream()即可

HttpClient client=new HttpClient();

GetMethod method=new GetMethod(URL);

PostMethod method = new PostMethod(URL);

client.executeMethod(method);

InputStream inputStream = method.getResponseBodyAsStream();  

BufferedReader br = new BufferedReader(new InputStreamReader(inputStream));  

StringBuffer stringBuffer = new StringBuffer();  

String str= "";  

while((str = br.readLine()) != null){  

    stringBuffer.append(str);  

 }

String  respStr = stringBuffer.toString();

这样就可以对返回的字符串respStr进行进一步解析了。

猜你喜欢

转载自blog.csdn.net/limengautoman/article/details/82736878