`

[转]HttpClient的超时用法小记

阅读更多
原文 http://blog.163.com/xing_mu_1/blog/static/6614290201032084947978/

HttpClient在使用中有两个超时时间,是一直接触和使用的,由于上次工作中使用httpClient造成了系统悲剧的情况,特地对它的两个超时时间进行了小小的测试,在这里记录下。


     测试版本为HttpClient——3.1



     一:连接超时:connectionTimeout



     1:指的是连接一个url的连接等待时间。



     2:设置方法为:



     public class TestHttpClientMain {

/**
  * @param args
  */
public static void main(String[] args) {
  HttpClient client = new HttpClient();

  HttpMethod method = new GetMethod(
    "http://test.com");
  client.getHttpConnectionManager().getParams()
    .setConnectionTimeout(3000);
  client.getHttpConnectionManager().getParams().setSoTimeout(3000);
  try {
   int statusCode = client.executeMethod(method);
   System.out.println(statusCode);

   byte[] responseBody = null;

   responseBody = method.getResponseBody();

   String result = new String(responseBody);

   System.out.println(result);

  } catch (HttpException e) {
   // TODO Auto-generated catch block
   e.printStackTrace();
  } catch (IOException e) {
   // TODO Auto-generated catch block
   e.printStackTrace();
  }
}



     3:测试的时候,将url改为一个不存在的url:“http://test.com”



     4:超时时间3000ms过后,系统报出异常。



     org.apache.commons.httpclient.ConnectTimeoutException: The host did not accept the connection within timeout of 3000 ms

at org.apache.commons.httpclient.protocol.ReflectionSocketFactory.createSocket(ReflectionSocketFactory.java:155)
at org.apache.commons.httpclient.protocol.DefaultProtocolSocketFactory.createSocket(DefaultProtocolSocketFactory.java:125)
at org.apache.commons.httpclient.HttpConnection.open(HttpConnection.java:707)
at org.apache.commons.httpclient.HttpMethodDirector.executeWithRetry(HttpMethodDirector.java:387)
at org.apache.commons.httpclient.HttpMethodDirector.executeMethod(HttpMethodDirector.java:171)
at org.apache.commons.httpclient.HttpClient.executeMethod(HttpClient.java:397) 


     二:读取数据超时:soTimeout



     1:指的是连接上一个url,获取response的返回等待时间



     2:设置方法



     public class TestHttpClientMain {

/**
  * @param args
  */
public static void main(String[] args) {
  HttpClient client = new HttpClient();

  HttpMethod method = new GetMethod(
    "http://localhost:8080/firstTest.htm?method=test");
  client.getHttpConnectionManager().getParams()
    .setConnectionTimeout(3000);
  client.getHttpConnectionManager().getParams().setSoTimeout(2000);
  try {
   int statusCode = client.executeMethod(method);
   System.out.println(statusCode);

   byte[] responseBody = null;

   responseBody = method.getResponseBody();

   String result = new String(responseBody);

   System.out.println(result);

  } catch (HttpException e) {
   // TODO Auto-generated catch block
   e.printStackTrace();
  } catch (IOException e) {
   // TODO Auto-generated catch block
   e.printStackTrace();
  }
}



     3:测试的时候的连接url为我本地开启的一个url,http://localhost:8080/firstTest.htm?method=test



     在我这个测试url里,当访问到这个链接时,线程sleep一段时间,来模拟返回response超时。



     @RequestMapping(params = "method=test") //<——②

    public String testMethod(ModelMap model) {
  try {
   Thread.sleep(3000);
  } catch (InterruptedException e) {
   // TODO Auto-generated catch block
   e.printStackTrace();
  }
        System.out.println("call testMethod method.");
        model.addAttribute("name", "test method");
  return "test";
    }



     4:将读取response返回超时时间设的时间比那个sleep时间短之后,运行程序给出异常:



      java.net.SocketTimeoutException: Read timed out

at java.net.SocketInputStream.socketRead0(Native Method)
at java.net.SocketInputStream.read(Unknown Source)
at java.io.BufferedInputStream.fill(Unknown Source)
at java.io.BufferedInputStream.read(Unknown Source)
at org.apache.commons.httpclient.HttpParser.readRawLine(HttpParser.java:78)
at org.apache.commons.httpclient.HttpParser.readLine(HttpParser.java:106)
at org.apache.commons.httpclient.HttpConnection.readLine(HttpConnection.java:1116)
at org.apache.commons.httpclient.HttpMethodBase.readStatusLine(HttpMethodBase.java:1973)
at org.apache.commons.httpclient.HttpMethodBase.readResponse(HttpMethodBase.java:1735) 




分享到:
评论

相关推荐

    Httpclient使用jar包三合一,基本使用方法

    简单使用方法: public static void main(String[] args) { // String str1 = &quot;http://dev.d-smart.cn/Login&quot;; // http协议路径 String str1 = &quot;&quot;; HttpClient httpClient = new ...

    httpclient用法,发送get和post请求,设置header

    httpclient的用法,发送get请求和post请求,设置header

    HttpClient 基本用法

    HttpClient 基本用法,HttpClient 基本用法

    HttpClient用法,实例

    HttpClient用法,实例 HttpClient用法,实例 HttpClient用法,实例 HttpClient用法,实例

    HttpClient各种使用方法

    NULL 博文链接:https://wenkaixuan.iteye.com/blog/2109590

    【ASP.NET编程知识】.NET CORE HttpClient的使用方法.docx

    【ASP.NET编程知识】.NET CORE HttpClient的使用方法.docx

    java httpclient设置超时时间和代理的方法

    主要介绍了java httpclient设置超时时间和代理的方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

    HttpClient用法

    HttpClient获得客户端信息(XML),返回服务器一个地址类似于:http://download.csdn.net/download/yonsin/4129984

    httpclient-4.5.6-API文档-中文版.zip

    赠送jar包:httpclient-4.5.6.jar;...使用方法:解压翻译后的API文档,用浏览器打开“index.html”文件,即可纵览文档内容。 人性化翻译,文档中的代码和结构保持不变,注释和说明精准翻译,请放心使用。

    HttpClient工具类封装.docx

    HttpClient工具类封装,基于httpclient4.5.12,有get、post、put、delete方法,可设置连接超时时间,请求超时时间,socket读写超时时间,设置是否允许重定向,字符集

    HttpClient4.5.1手册

    HttpClient4.5.1,官方版手册

    httpClient

    * 方法。 4:处理响应状态码。 5:若响应正常,处理 HTTP 响应内容。 6:释放连接。 */ /* 1 生成 HttpClinet 对象并设置参数 */ HttpClient httpClient = new HttpClient(); // 设置 Http 连接超时为5秒 ...

    httpclient使用帮助类

    httpclient是Apache Jakarta Common 下的子项目,可以用来提供高效的、最新的、功能丰富的支持 HTTP 协议的客户端编程工具包,本文档提供使用httpclient的使用方法

    HttpClient以及获取页面内容应用

    1.4使用方法与步骤 开发环境:需要 使用HttpClient发送请求、接收响应很简单,一般需要如下几步即可。 1.创建HttpClient对象。 HttpClient client = new HttpClient(); 2.创建请求方法的实例,并指定请求URL。如果...

    httpclient

    httpclient

    httpclient-4.5.5-API文档-中文版.zip

    赠送jar包:httpclient-4.5.5.jar;...使用方法:解压翻译后的API文档,用浏览器打开“index.html”文件,即可纵览文档内容。 人性化翻译,文档中的代码和结构保持不变,注释和说明精准翻译,请放心使用。

    httpclient httpclient.jar

    httpClient完整封装获取网页信息、数据的代码+httpclient.jar

Global site tag (gtag.js) - Google Analytics