HttpClient4.2.2的几个常用方法,登录之后访问页面问题,下载文件

简介: 在工作中要用到android,然后进行网络请求的时候,打算使用httpClient。 总结一下httpClient的一些基本使用。 版本是4.2.2。 使用这个版本的过程中,百度很多,结果都是出现的org.apache.commons.httpclient.这个包名,而不是我这里的org.apache.http.client.HttpClient----------前者版本是Commons HttpClient 3.x ,不是最新的版本HttpClient 4.×。

在工作中要用到android,然后进行网络请求的时候,打算使用httpClient。

总结一下httpClient的一些基本使用。

版本是4.2.2。

使用这个版本的过程中,百度很多,结果都是出现的org.apache.commons.httpclient.这个包名,而不是我这里的org.apache.http.client.HttpClient----------前者版本是Commons HttpClient 3.x ,不是最新的版本HttpClient 4.×。

官网上面:

Commons HttpClient 3.x codeline is at the end of life. All users of Commons  HttpClient 3.x are strongly encouraged to upgrade to HttpClient 4.1. 

1.基本的get

Java代码 复制代码 收藏代码
  1. public void getUrl(String url, String encoding) 
  2.             throws ClientProtocolException, IOException { 
  3.         // 默认的client类。 
  4.         HttpClient client = new DefaultHttpClient(); 
  5.         // 设置为get取连接的方式. 
  6.         HttpGet get = new HttpGet(url); 
  7.         // 得到返回的response. 
  8.         HttpResponse response = client.execute(get); 
  9.         // 得到返回的client里面的实体对象信息. 
  10.         HttpEntity entity = response.getEntity(); 
  11.         if (entity != null) { 
  12.             System.out.println("内容编码是:" + entity.getContentEncoding()); 
  13.             System.out.println("内容类型是:" + entity.getContentType()); 
  14.             // 得到返回的主体内容. 
  15.             InputStream instream = entity.getContent(); 
  16.             try
  17.                 BufferedReader reader = new BufferedReader( 
  18.                         new InputStreamReader(instream, encoding)); 
  19.                 System.out.println(reader.readLine()); 
  20.             } catch (Exception e) { 
  21.                 e.printStackTrace(); 
  22.             } finally
  23.                 instream.close(); 
  24.             } 
  25.         } 
  26.  
  27.         // 关闭连接. 
  28.         client.getConnectionManager().shutdown(); 
  29.     } 

2.基本的Post

   下面的params参数,是在表单里面提交的参数。

Java代码 复制代码 收藏代码
  1. public void postUrlWithParams(String url, Map params, String encoding) 
  2.             throws Exception { 
  3.         DefaultHttpClient httpclient = new DefaultHttpClient(); 
  4.         try
  5.  
  6.             HttpPost httpost = new HttpPost(url); 
  7.             // 添加参数 
  8.             List<NameValuePair> nvps = new ArrayList<NameValuePair>(); 
  9.             if (params != null && params.keySet().size() >0) { 
  10.                 Iterator iterator = params.entrySet().iterator(); 
  11.                 while (iterator.hasNext()) { 
  12.                     Map.Entry entry = (Entry) iterator.next(); 
  13.                     nvps.add(new BasicNameValuePair((String) entry.getKey(), 
  14.                             (String) entry.getValue())); 
  15.                 } 
  16.             } 
  17.  
  18.             httpost.setEntity(new UrlEncodedFormEntity(nvps, Consts.UTF_8)); 
  19.  
  20.             HttpResponse response = httpclient.execute(httpost); 
  21.             HttpEntity entity = response.getEntity(); 
  22.  
  23.             System.out.println("Login form get: " + response.getStatusLine() 
  24.                     + entity.getContent()); 
  25.             dump(entity, encoding); 
  26.             System.out.println("Post logon cookies:"); 
  27.             List<Cookie> cookies = httpclient.getCookieStore().getCookies(); 
  28.             if (cookies.isEmpty()) { 
  29.                 System.out.println("None"); 
  30.             } else
  31.                 for (int i =0; i < cookies.size(); i++) { 
  32.                     System.out.println("- " + cookies.get(i).toString()); 
  33.                 } 
  34.             } 
  35.  
  36.         } finally
  37.             // 关闭请求 
  38.             httpclient.getConnectionManager().shutdown(); 
  39.         } 
  40.     } 

3。打印页面输出的小代码片段

Java代码 复制代码 收藏代码
  1. private staticvoid dump(HttpEntity entity, String encoding) 
  2.             throws IOException { 
  3.         BufferedReader br = new BufferedReader(new InputStreamReader( 
  4.                 entity.getContent(), encoding)); 
  5.         System.out.println(br.readLine()); 
  6.     } 

4.常见的登录session问题,需求:使用账户,密码登录系统之后,然后再访问页面不出错。

特别注意,下面的httpclient对象要使用一个,而不要在第二次访问的时候,重新new一个。至于如何保存这个第一步经过了验证的httpclient,有很多种方法实现。单例,系统全局变量(android 下面的Application),ThreadLocal变量等等。

       以及下面创建的httpClient要使用ThreadSafeClientConnManager对象!

   public String getSessionId(String url, Map params, String encoding,

Java代码 复制代码 收藏代码
  1.         String url2) throws Exception { 
  2.     DefaultHttpClient httpclient = new DefaultHttpClient( 
  3.             new ThreadSafeClientConnManager()); 
  4.     try
  5.  
  6.         HttpPost httpost = new HttpPost(url); 
  7.         // 添加参数 
  8.         List<NameValuePair> nvps = new ArrayList<NameValuePair>(); 
  9.         if (params != null && params.keySet().size() >0) { 
  10.             Iterator iterator = params.entrySet().iterator(); 
  11.             while (iterator.hasNext()) { 
  12.                 Map.Entry entry = (Entry) iterator.next(); 
  13.                 nvps.add(new BasicNameValuePair((String) entry.getKey(), 
  14.                         (String) entry.getValue())); 
  15.             } 
  16.         } 
  17.         // 设置请求的编码格式 
  18.         httpost.setEntity(new UrlEncodedFormEntity(nvps, Consts.UTF_8)); 
  19.         // 登录一遍 
  20.         httpclient.execute(httpost); 
  21.         // 然后再第二次请求普通的url即可。 
  22.         httpost = new HttpPost(url2); 
  23.         BasicResponseHandler responseHandler = new BasicResponseHandler(); 
  24.         System.out.println(httpclient.execute(httpost, responseHandler)); 
  25.     } finally
  26.         // 关闭请求 
  27.         httpclient.getConnectionManager().shutdown(); 
  28.     } 
  29.     return ""

5.下载文件,例如mp3等等。

Java代码 复制代码 收藏代码
  1. //第一个参数,网络连接;第二个参数,保存到本地文件的地址 
  2. public void getFile(String url, String fileName) { 
  3.         HttpClient httpClient = new DefaultHttpClient(); 
  4.         HttpGet get = new HttpGet(url); 
  5.         try
  6.             ResponseHandler<byte[]> handler =new ResponseHandler<byte[]>() { 
  7.                 public byte[] handleResponse(HttpResponse response) 
  8.                         throws ClientProtocolException, IOException { 
  9.                     HttpEntity entity = response.getEntity(); 
  10.                     if (entity != null) { 
  11.                         return EntityUtils.toByteArray(entity); 
  12.                     } else
  13.                         return null
  14.                     } 
  15.                 } 
  16.             }; 
  17.  
  18.             byte[] charts = httpClient.execute(get, handler); 
  19.             FileOutputStream out = new FileOutputStream(fileName); 
  20.             out.write(charts); 
  21.             out.close(); 
  22.  
  23.         } catch (Exception e) { 
  24.             e.printStackTrace(); 
  25.         } finally
  26.             httpClient.getConnectionManager().shutdown(); 
  27.         } 
  28.     } 

6.创建一个多线程环境下面可用的httpClient

(原文:http://blog.csdn.net/jiaoshi0531/article/details/6459468

Java代码 复制代码 收藏代码
  1.               HttpParams params = new BasicHttpParams(); 
  2. //设置允许链接的做多链接数目 
  3. ConnManagerParams.setMaxTotalConnections(params, 200); 
  4. //设置超时时间. 
  5. ConnManagerParams.setTimeout(params, 10000); 
  6. //设置每个路由的最多链接数量是20 
  7. ConnPerRouteBean connPerRoute = new ConnPerRouteBean(20); 
  8. //设置到指定主机的路由的最多数量是50 
  9. HttpHost localhost = new HttpHost("127.0.0.1",80); 
  10. connPerRoute.setMaxForRoute(new HttpRoute(localhost),50); 
  11. ConnManagerParams.setMaxConnectionsPerRoute(params, connPerRoute); 
  12. //设置链接使用的版本 
  13. HttpProtocolParams.setVersion(params, HttpVersion.HTTP_1_1); 
  14. //设置链接使用的内容的编码 
  15. HttpProtocolParams.setContentCharset(params, 
  16.         HTTP.DEFAULT_CONTENT_CHARSET); 
  17. //是否希望可以继续使用. 
  18. HttpProtocolParams.setUseExpectContinue(params, true); 
  19.  
  20. SchemeRegistry schemeRegistry = new SchemeRegistry(); 
  21. schemeRegistry.register(new Scheme("http",PlainSocketFactory.getSocketFactory(),80)); 
  22. schemeRegistry.register(new Scheme("https",SSLSocketFactory.getSocketFactory(),443)); 
  23. ClientConnectionManager cm = new ThreadSafeClientConnManager(params,schemeRegistry); 
  24. httpClient = new DefaultHttpClient(cm, params);  

7.实用的一个对象,http上下文,可以从这个对象里面取到一次请求相关的信息,例如request,response,代理主机等。

Java代码 复制代码 收藏代码
  1. public staticvoid getUrl(String url, String encoding) 
  2.             throws ClientProtocolException, IOException { 
  3.         // 设置为get取连接的方式. 
  4.         HttpGet get = new HttpGet(url); 
  5.         HttpContext localContext = new BasicHttpContext(); 
  6.         // 得到返回的response.第二个参数,是上下文,很好的一个参数! 
  7.         httpclient.execute(get, localContext); 
  8.  
  9.         // 从上下文中得到HttpConnection对象 
  10.         HttpConnection con = (HttpConnection) localContext 
  11.                 .getAttribute(ExecutionContext.HTTP_CONNECTION); 
  12.         System.out.println("socket超时时间:" + con.getSocketTimeout()); 
  13.  
  14.         // 从上下文中得到HttpHost对象 
  15.         HttpHost target = (HttpHost) localContext 
  16.                 .getAttribute(ExecutionContext.HTTP_TARGET_HOST); 
  17.         System.out.println("最终请求的目标:" + target.getHostName() +":" 
  18.                 + target.getPort()); 
  19.  
  20.         // 从上下文中得到代理相关信息. 
  21.         HttpHost proxy = (HttpHost) localContext 
  22.                 .getAttribute(ExecutionContext.HTTP_PROXY_HOST); 
  23.         if (proxy != null
  24.             System.out.println("代理主机的目标:" + proxy.getHostName() +":" 
  25.                     + proxy.getPort()); 
  26.  
  27.         System.out.println("是否发送完毕:" 
  28.                 + localContext.getAttribute(ExecutionContext.HTTP_REQ_SENT)); 
  29.  
  30.         // 从上下文中得到HttpRequest对象 
  31.         HttpRequest request = (HttpRequest) localContext 
  32.                 .getAttribute(ExecutionContext.HTTP_REQUEST); 
  33.         System.out.println("请求的版本:" + request.getProtocolVersion()); 
  34.         Header[] headers = request.getAllHeaders(); 
  35.         System.out.println("请求的头信息: "); 
  36.         for (Header h : headers) { 
  37.             System.out.println(h.getName() + "--" + h.getValue()); 
  38.         } 
  39.         System.out.println("请求的链接:" + request.getRequestLine().getUri()); 
  40.  
  41.         // 从上下文中得到HttpResponse对象 
  42.         HttpResponse response = (HttpResponse) localContext 
  43.                 .getAttribute(ExecutionContext.HTTP_RESPONSE); 
  44.         HttpEntity entity = response.getEntity(); 
  45.         if (entity != null) { 
  46.             System.out.println("返回结果内容编码是:" + entity.getContentEncoding()); 
  47.             System.out.println("返回结果内容类型是:" + entity.getContentType()); 
  48.             dump(entity, encoding); 
  49.         } 
  50.     } 

输出结果大致如下:

Txt代码 复制代码 收藏代码
  1. socket超时时间:0 
  2. 最终请求的目标:money.finance.sina.com.cn:-1 
  3. 是否发送完毕:true 
  4. 请求的版本:HTTP/1.1 
  5. 请求的头信息:  
  6. Host--money.finance.sina.com.cn 
  7. Connection--Keep-Alive 
  8. User-Agent--Apache-HttpClient/4.2.2 (java1.5
  9. 请求的链接:/corp/go.php/vFD_BalanceSheet/stockid/600031/ctrl/part/displaytype/4.phtml 
  10. 返回结果内容编码是:null 
  11. 返回结果内容类型是:Content-Type: text/html 

8.设置代理

Java代码 复制代码 收藏代码
  1.              //String  hostIp代理主机ip,int port  代理端口 
  2. tpHost proxy = new HttpHost(hostIp, port); 
  3. // 设置代理主机. 
  4. tpclient.getParams().setParameter(ConnRoutePNames.DEFAULT_PROXY, 
  5. proxy); 

9.设置保持链接时间

Java代码 复制代码 收藏代码
  1. //在服务端设置一个保持持久连接的特性. 
  2.         //HTTP服务器配置了会取消在一定时间内没有活动的链接,以节省系统的持久性链接资源. 
  3.         httpClient.setKeepAliveStrategy(new ConnectionKeepAliveStrategy() { 
  4.             public long getKeepAliveDuration(HttpResponse response, 
  5.                     HttpContext context) { 
  6.                 HeaderElementIterator it = new BasicHeaderElementIterator( 
  7.                         response.headerIterator(HTTP.CONN_KEEP_ALIVE)); 
  8.                 while (it.hasNext()) { 
  9.                     HeaderElement he = it.nextElement(); 
  10.                     String param = he.getName(); 
  11.                     String value = he.getValue(); 
  12.                     if (value != null && param.equalsIgnoreCase("timeout")) { 
  13.                         try
  14.                             return Long.parseLong(value) *1000
  15.                         } catch (Exception e) { 
  16.  
  17.                         } 
  18.                     } 
  19.                 } 
  20.                 HttpHost target = (HttpHost)context.getAttribute(ExecutionContext.HTTP_TARGET_HOST); 
  21.                 if("www.baidu.com".equalsIgnoreCase(target.getHostName())){ 
  22.                     return 5*1000
  23.                 } 
  24.                 else 
  25.                     return 30*1000;  
  26.             }  
  27.         }); 

转账注明出处:http://renjie120.iteye.com/blog/1727933

相关文章
09JavaWeb基础 - Response类案例(下载文件)
09JavaWeb基础 - Response类案例(下载文件)
213 0
|
5月前
|
Java
Java通过HttpClient从外部url下载文件到本地
该Java程序旨在通过URL将外部网络文件(如图片)下载至本地,并解决防盗链问题。首先,它通过`HttpGet`请求获取远程文件,并通过设置`Referer`头防止防盗链。然后,根据响应内容类型确定文件后缀并保存至指定路径。测试表明,程序能够成功下载文件。
647 8
Java通过HttpClient从外部url下载文件到本地
|
4月前
|
JSON 前端开发 JavaScript
java中post请求调用下载文件接口浏览器未弹窗而是返回一堆json,为啥
客户端调接口需要返回另存为弹窗,下载文件,但是遇到的问题是接口调用成功且不报错,浏览器F12查看居然返回一堆json,而没有另存为弹窗; > 正确的效果应该是:接口调用成功且浏览器F12不返回任何json,而是弹窗另存为窗口,直接保存文件即可。
185 2
不同的浏览器创建的对象是不同的
不同的浏览器创建的对象是不同的
|
7月前
|
安全 Java Maven
如何使用jsoup实现网站登录,cookie保存,查询信息
【6月更文挑战第11天】如何使用jsoup实现网站登录,cookie保存,查询信息
261 1
|
8月前
文件上传地址的获取方法
文件上传地址的获取方法
69 1
|
前端开发
前端:下载文件(多种方法)
前端:下载文件(多种方法)
903 0
|
网络协议 前端开发 JavaScript
一个浏览器从加载URL到页面展示出来,经过了哪些步骤?
一个浏览器从加载URL到页面展示出来,经过了哪些步骤?
|
移动开发
详解IIS中的重写工具下关于操作重定向URL中的{R:N}与{C:N}
详解IIS中的重写工具下关于操作重定向URL中的{R:N}与{C:N}
222 0
详解IIS中的重写工具下关于操作重定向URL中的{R:N}与{C:N}

热门文章

最新文章