HttpClient使用详解

使用HttpClient发送请求、接收响应很简单,一般需要如下几步即可。

1. 创建HttpClient对象。

2. 创建请求方法的实例,并指定请求URL。如果需要发送GET请求,创建HttpGet对象;如果需要发送POST请求,创建HttpPost对象。

3. 如果需要发送请求参数,可调用HttpGet、HttpPost共同的setParams(HetpParams params)方法来添加请求参数;对于HttpPost对象而言,也可调用setEntity(HttpEntity entity)方法来设置请求参数。

4. 调用HttpClient对象的execute(HttpUriRequest request)发送请求,该方法返回一个HttpResponse。

5. 调用HttpResponse的getAllHeaders()、getHeaders(String name)等方法可获取服务器的响应头;调用HttpResponse的getEntity()方法可获取HttpEntity对象,该对象包装了服务器的响应内容。程序可通过该对象获取服务器的响应内容。

6. 释放连接。无论执行方法是否成功,都必须释放连接。

代码:

/**
  *
  * @Title : byPostMethodToHttpEntity
  * @param @param url
  * @param @param params
  * @param @param urlEncoded
  * @param @return
  * @return String
  * @author ymn
  * @date 2016-4-20 下午04:08:46
  */
 public static String byPostMethodToHttpEntity(String url,
   List<NameValuePair> params,String urlEncoded){
  
  HttpEntity entity = null;
  StringBuffer buff = new StringBuffer();
  // 创建线程安全的httpClient
  HttpClient  httpClient = new DefaultHttpClient(new ThreadSafeClientConnManager());//创建HttpClient对象
  HttpPost httpPost = new HttpPost(url);//指定请求URL
  try {
   if(params != null){
    UrlEncodedFormEntity uefEntity = new UrlEncodedFormEntity(params,
      urlEncoded);//为提交参数进行编码,urlEncoded为UTF-8
    httpPost.setEntity(uefEntity);
   }
   HttpResponse response = httpClient.execute(httpPost);//发送请求
   if (HttpStatus.SC_OK == response.getStatusLine().getStatusCode()) {
    entity = response.getEntity();
    buff.append(EntityUtils.toString(entity));
   }
  } catch (ClientProtocolException e) {
   e.printStackTrace();
  } catch (IOException e) {
   e.printStackTrace();
  } finally {
   releaseSource(null, httpPost, httpClient);
  }
  return buff.toString();
 }
 /**
  * 释放资源
  * @param httpGet
  * @param httpPost
  * @param httpClient
  */
 public static void releaseSource(HttpGet httpGet,
   HttpPost httpPost, HttpClient httpClient) {
  if (httpGet != null) {
   httpGet.abort();
  }
  if (httpPost != null) {
   httpPost.abort();
  }
  if (httpClient != null) {
   httpClient.getConnectionManager().shutdown();//关闭连接
  }
 }

说明:ThreadSafeClientConnManager是一个复杂的实现来管理客户端连接池,它也可以从多个执行线程中服务连接请求。对每个基本的路由,连接都是池管理的。对于路由的请求,管理器在池中有可用的持久性连接,将被从池中租赁连接服务,而不是创建一个新的连接。ThreadSafeClientConnManager维护每个基本路由的最大连接限制。每个默认的实现对每个给定路由将会创建不超过两个的并发连接,而总共也不会超过20个连接。对于很多真实的应用程序,这个限制也证明很大的制约,特别是他们在服务中使用HTTP作为传输协议。连接限制,也可以使用HTTP参数来进行调整。

其中HttpClient 是接口,DefaultHttpClient是实现这个接口的子类。

 

 

转载于:https://my.oschina.net/yangfeima/blog/663099

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值