jar包

HttpClient 4.x版本

简要介绍

HttpComponents 包括 HttpCore包和HttpClient包

HttpClient:Http的执行http请求

DefaultHttpClient:httpClient默认实现

HttpGet、HttpPost:Get、Post方法执行类

HttpResponse:执行返回的Response,含http的header和执行结果实体Entity

HttpEntity:Http返回结果实体,不含Header内容

HttpParam:连接参数,配合连接池使用

PoolingClientConnectionManager:连接池

基础Get方法

  1. // 默认的client类。
  2. HttpClient client = new DefaultHttpClient();
  3. // 设置为get取连接的方式.
  4. HttpGet get = new HttpGet(url);
  5. // 得到返回的response.
  6. HttpResponse response = client.execute(get);
  7. // 得到返回的client里面的实体对象信息.
  8. HttpEntity entity = response.getEntity();
  9. if (entity != null) {
  10. System.out.println( entity.getContentEncoding());
  11. System.out.println( entity.getContentType());
  12. // 得到返回的主体内容.
  13. InputStream instream = entity.getContent();
  14. BufferedReader reader = new BufferedReader(new InputStreamReader(instream, encoding));
  15. System.out.println(reader.readLine());
  16. // EntityUtils 处理HttpEntity的工具类
  17. // System.out.println(EntityUtils.toString(entity));
  18. }
  19. // 关闭连接.
  20. client.getConnectionManager().shutdown();

基础Post方法

  1. DefaultHttpClient httpclient = new DefaultHttpClient();
  2. HttpPost httpost = new HttpPost(url);
  3. // 添加参数
  4. List<NameValuePair> formparams = new ArrayList<NameValuePair>();
  5. formparams.add(new BasicNameValuePair("p", "1"));
  6. formparams.add(new BasicNameValuePair("t", "2"));
  7. formparams.add(new BasicNameValuePair("e", "3"));
  8. UrlEncodedFormEntity urlEntity =  new UrlEncodedFormEntity(formparams, "UTF-8");
  9. httpost.setEntity(urlEntity);
  10. HttpResponse response = httpclient.execute(httpost);
  11. HttpEntity entity = response.getEntity();
  12. System.out.println("Login form get: " + response.getStatusLine() + entity.getContent());
  13. //  dump(entity, encoding);
  14. System.out.println("Post logon cookies:");
  15. List<Cookie> cookies = httpclient.getCookieStore().getCookies();
  16. for (int i = 0; i < cookies.size(); i++) {
  17. System.out.println("- " + cookies.get(i).toString());
  18. }
  19. // 关闭请求
  20. httpclient.getConnectionManager().shutdown();

保留Session,保留用户+密码状态

Demo1,只支持单线程

  1. DefaultHttpClient httpclient = new DefaultHttpClient(
  2. new ThreadSafeClientConnManager());
  3. HttpPost httpost = new HttpPost(url);
  4. // 添加参数
  5. List<NameValuePair> formparams = new ArrayList<NameValuePair>();
  6. formparams.add(new BasicNameValuePair("p", "1"));
  7. formparams.add(new BasicNameValuePair("t", "2"));
  8. formparams.add(new BasicNameValuePair("e", "3"));
  9. // 设置请求的编码格式
  10. httpost.setEntity(new UrlEncodedFormEntity(formparams, Consts.UTF_8));
  11. // 登录一遍
  12. httpclient.execute(httpost);
  13. // 然后再第二次请求普通的url即可。
  14. httpost = new HttpPost(url2);
  15. BasicResponseHandler responseHandler = new BasicResponseHandler();
  16. System.out.println(httpclient.execute(httpost, responseHandler));
  17. httpclient.getConnectionManager().shutdown();
  18. return "";

Demo2:第二次请求带上第一次请求的Cookie

用于在用户+密码等候后,后续根据第一次请求的URL获取的Cookie,把这些Cookie添加到第二次请求的Cookie中

  1. DefaultHttpClient httpclient = new DefaultHttpClient();
  2. HttpPost httpost = new HttpPost(url);
  3. // 添加参数
  4. List<NameValuePair> formparams = new ArrayList<NameValuePair>();
  5. formparams.add(new BasicNameValuePair("uname", name));
  6. formparams.add(new BasicNameValuePair("pass", "e0c10f451217b93f76c2654b2b729b85"));
  7. formparams.add(new BasicNameValuePair("auto_login","0"));
  8. formparams.add(new BasicNameValuePair("a","1"));
  9. formparams.add(new BasicNameValuePair("backurl","1"));
  10. UrlEncodedFormEntity urlEntity =  new UrlEncodedFormEntity(formparams, "UTF-8");
  11. httpost.setEntity(urlEntity);
  12. HttpContext localContext = new BasicHttpContext();
  13. HttpResponse response = httpclient.execute(httpost,localContext);
  14. HttpEntity entity = response.getEntity();
  15. // 打印获取值
  16. System.out.println(Arrays.toString(response.getAllHeaders()));
  17. System.out.println(EntityUtils.toString(entity));
  18. // 第二次请求,使用上一次请求的Cookie
  19. DefaultHttpClient httpclient2 = new DefaultHttpClient();
  20. HttpPost httpost2 = new HttpPost("http://my.ifeng.com/?_c=index&_a=my");
  21. // 获取上一次请求的Cookie
  22. CookieStore cookieStore2 = httpclient2.getCookieStore();
  23. // 下一次的Cookie的值,将使用上一次请求
  24. CookieStore cookieStore = httpclient.getCookieStore();
  25. List<Cookie> list = cookieStore.getCookies();
  26. for(Cookie o : list){
  27. System.out.println(o.getName() + " = " + o.getValue() + " 12");;
  28. cookieStore2.addCookie(o);
  29. }
  30. HttpResponse response2 = httpclient2.execute(httpost2);
  31. HttpEntity entity2 = response2.getEntity();
  32. System.out.println(Arrays.toString(response2.getAllHeaders()));
  33. System.out.println(EntityUtils.toString(entity2));

获取访问上下文

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

连接池和代理:

每次使用最后一句new DefaultHttpClient(cm, httpParams);获取新的HttpClient

里面还有一条如何设置代理

  1. // HttpParams
  2. HttpParams httpParams  = new BasicHttpParams();
  3. // HttpConnectionParams 设置连接参数
  4. // 设置连接超时时间
  5. HttpConnectionParams.setConnectionTimeout(httpParams, 30000);
  6. // 设置读取超时时间
  7. HttpConnectionParams.setSoTimeout(httpParams, 60000);
  8. SchemeRegistry schemeRegistry = new SchemeRegistry();
  9. schemeRegistry.register(
  10. new Scheme("http", 80, PlainSocketFactory.getSocketFactory()));
  11. //      schemeRegistry.register(
  12. //               new Scheme("https", 443, SSLSocketFactory.getSocketFactory()));
  13. PoolingClientConnectionManager cm = new PoolingClientConnectionManager(schemeRegistry);
  14. // 设置最大连接数
  15. cm.setMaxTotal(200);
  16. // 设置每个路由默认最大连接数
  17. cm.setDefaultMaxPerRoute(20);
  18. //      // 设置代理和代理最大路由
  19. //      HttpHost localhost = new HttpHost("locahost", 80);
  20. //      cm.setMaxPerRoute(new HttpRoute(localhost), 50);
  21. // 设置代理,
  22. HttpHost proxy = new HttpHost("10.36.24.3", 60001);
  23. httpParams.setParameter(ConnRoutePNames.DEFAULT_PROXY,  proxy);
  24. HttpClient httpClient = new DefaultHttpClient(cm, httpParams);

自动重连

如果某次请求请求失败,可以自动重连

  1. DefaultHttpClient httpClient = new DefaultHttpClient();
  2. // 可以自动重连
  3. HttpRequestRetryHandler requestRetryHandler2 = new HttpRequestRetryHandler() {
  4. // 自定义的恢复策略
  5. public synchronized boolean retryRequest(IOException exception, int executionCount, HttpContext context) {
  6. // 设置恢复策略,在发生异常时候将自动重试3次
  7. if (executionCount > 3) {
  8. // 超过最大次数则不需要重试
  9. return false;
  10. }
  11. if (exception instanceof NoHttpResponseException) {
  12. // 服务停掉则重新尝试连接
  13. return true;
  14. }
  15. if (exception instanceof SSLHandshakeException) {
  16. // SSL异常不需要重试
  17. return false;
  18. }
  19. HttpRequest request = (HttpRequest) context.getAttribute(ExecutionContext.HTTP_REQUEST);
  20. boolean idempotent = (request instanceof HttpEntityEnclosingRequest);
  21. if (!idempotent) {
  22. // 请求内容相同则重试
  23. return true;
  24. }
  25. return false;
  26. }
  27. };
  28. httpClient.setHttpRequestRetryHandler(requestRetryHandler2);

使用自定义ResponseHandler处理返回的请求

  1. HttpClient httpClient = new DefaultHttpClient();
  2. HttpGet get = new HttpGet(url);
  3. // 定义一个类处理URL返回的结果
  4. ResponseHandler<byte[]> handler = new ResponseHandler<byte[]>() {
  5. public byte[] handleResponse(HttpResponse response)
  6. throws ClientProtocolException, IOException {
  7. HttpEntity entity = response.getEntity();
  8. if (entity != null) {
  9. return EntityUtils.toByteArray(entity);
  10. } else {
  11. return null;
  12. }
  13. }
  14. };
  15. // 不同于 httpClient.execute(request),返回值是HttpResponse;返回值右ResponseHandler决定
  16. byte[] charts = httpClient.execute(get, handler);
  17. FileOutputStream out = new FileOutputStream(fileName);
  18. out.write(charts);
  19. out.close();
  20. httpClient.getConnectionManager().shutdown();

参考文献

HttpClient学习系列 -- 学习总结的更多相关文章

  1. Identity Server4学习系列四之用户名密码获得访问令牌

    1.简介 Identity Server4支持用户名密码模式,允许调用客户端使用用户名密码来获得访问Api资源(遵循Auth 2.0协议)的Access Token,MS可能考虑兼容老的系统,实现了这 ...

  2. Identity Server4学习系列三

    1.简介 在Identity Server4学习系列一和Identity Server4学习系列二之令牌(Token)的概念的基础上,了解了Identity Server4的由来,以及令牌的相关知识, ...

  3. SpringCloud学习系列之七 ----- Zuul路由网关的过滤器和异常处理

    前言 在上篇中介绍了SpringCloud Zuul路由网关的基本使用版本,本篇则介绍基于SpringCloud(基于SpringBoot2.x,.SpringCloud Finchley版)中的路由 ...

  4. 分布式学习系列【dubbo入门实践】

    分布式学习系列[dubbo入门实践] dubbo架构 组成部分:provider,consumer,registry,monitor: provider,consumer注册,订阅类似于消息队列的注册 ...

  5. Entity Framework Code First学习系列目录

    Entity Framework Code First学习系列说明:开发环境为Visual Studio 2010 + Entity Framework 5.0+MS SQL Server 2012, ...

  6. WCF学习系列汇总

    最近在学习WCF,打算把一整个系列的文章都”写“出来,包括理论和实践,这里的“写”是翻译,是国外的大牛写好的,我只是搬运工外加翻译.翻译的不好,大家请指正,谢谢了.如果觉得不错的话,也可以给我点赞,这 ...

  7. EF(Entity Framework)系统学习系列

    好久没写博客了,继续开启霸屏模式,好了,废话不多说,这次准备重新系统学一下EF,一个偶然的机会找到了一个学习EF的网站(http://www.entityframeworktutorial.net/) ...

  8. MVC学习系列4--@helper辅助方法和用户自定义HTML方法

    在HTML Helper,帮助类的帮助下,我们可以动态的创建HTML控件.HTML帮助类是在视图中,用来呈现HTML内容的.HTML帮助类是一个方法,它返回的是string类型的值. HTML帮助类, ...

  9. YYKit学习系列 ---- 开篇

    准备花半年时间系统学习YYKit,  学习过程会放入"YYKit学习系列"这个分类, 喜欢YYKit的可以随时留意我的文章, 一起学习!!!

随机推荐

  1. flex和layout移动端布局

    1.九宫格 样式为: ul{ display: flex; flex-wrap: wrap;//超出换行 } li{ width: 33%; height: 60px; display: flex; ...

  2. BZOJ 4547 矩阵快速幂

    思路: 肯定每回只加最大值和次大值 如果 一开始的最大值>0且次大值<0 那就一直加 加到次大值>0 搞一个矩阵 推斐波那契数列 求和 就好- //By SiriusRen #inc ...

  3. Android View事件分发与传递

    在Android中,人们主要通过手指与系统交互.Android把所有的touch事件都被封装成MotionEvent来进行处理,其中包括了手指点击的位置,时间等信息.其事件类型主要包括:ACTION_ ...

  4. Android + Eclipse + NDK + cygwin配制

    以前做NDK开发时留下来的笔记,希望对后继开发人员有所帮助,在开放给大家使用,有不对的地方请留,扔砖头都可以的. 为了方便在Win32下开发android C++ 程序,我们作了如下配制:1.Andr ...

  5. JAVA基本数据类型转换的注意事项

    JAVA中基本数据类型: 类型: 字节: 范围: 默认值: byte 1 -128~127 0 short 2 -32768~32767 0 char 2 0~65535 '\u0000' int 4 ...

  6. wordpress插件推荐

    以下插件可以全部到后台插件中心安装,只需使用关键词搜索即可 安全插件:Wordfence Security 后台增加一道密码:Stealth Login Page 隐藏后台登录地址:WPS-Hide- ...

  7. 资源帖:CV代码库搜集

    2013计算机视觉代码合集一: 原文链接:http://www.yuanyong.org/blog/cv/cv-code-one 切记:一定要看原文链接 原文链接: http://blog.csdn. ...

  8. spring之interceptor篇

    springmvc中要写一个拦截器非常的简单,有两种方式:要么实现HandlerInterceptor接口或者继承实现了该接口的类,如spring已经为我们写好的一个HandlerIntercepto ...

  9. Camera三维动画

    一.概述 在Android中说到3D开发,我们首先想到的是OpenGL,但用起来比较复杂繁琐,不适合做应用级别的3D变换.Android为我们提供了一个简化版的3D开发入口:Camera(这里的Cam ...

  10. linux下载命令wget

    Linux wget是一个下载文件的工具,它用在命令行下.对于Linux用户是必不可少的工具,尤其对于网络管理员,经常要下载一些软件或从远程服务器恢复备份到 本地服务器.如果我们使用虚拟主机,处理这样 ...