美文网首页
HttpClient 学习笔记(持续更新中)

HttpClient 学习笔记(持续更新中)

作者: Watson_Xu | 来源:发表于2017-09-13 11:32 被阅读0次

本文是博主在实习阶段所接触到的业务中所学到的关于HttpClient知识点总结。

前言


HttpClient是通过提供一个有效的、保持更新的、功能丰富的软件包来实现客户端最新的Http标准和建议(官方文档给出)。


基于HttpCore的客户端Http.

基于经典I/O

内容无关

一、执行请求

1、Http请求

HttpClient支持所有定义在Http/1.1,版本中的Http方法:Get、Post、Put、Delete、Trace、Options。对应每个方法类型都对应一个特殊的类:、HttpGet,HttpHead,HttpPost,HttpPut,HttpDelete,HttpTrace和HttpOptions。

最简单的请求是:

HttpGet httpGet= new HttpGet("http://www.baidu.com");

请求的uri也可以拼装,Http的URI包含一个协议模式、主机名称、可选的端口、资源路径、可选的查询、和可选的片段。

eg.

URI uri=URIUtils.createURI("http","www.baidu.com",-1,"/s","wd=httpCilent",null); 

HttpGet httpGet=newHttpGet(uri);  

System.out.println(httpGet.getURI());

输出为:

http://www.baidu.com/s?wd=httpClient

即在百度中搜索“httpClient”关键字的链接

查询字符串也可以从独立的参数中来生成:

Listparams=newArrayList();

params.add(newBasicNameValuePair("wd","httpClient"));

URI uri=URIUtils.createURI("http","www.baidu.com",-1,"/s", URLEncodedUtils.format(params,"utf-8"),null);

HttpGet httpGet =newHttpGet(uri);System.out.println(httpGet.getURI());

输出同样为:

http://www.baidu.com/s?wd=httpClient

2、Http响应

利用上面的httpGet请求可以得到相应的响应报文.

         获取响应报文中的协议版本、状态码和相关联的文本。

HttpClienthttpClient=newDefaultHttpClient();

HttpResponsehttpResponse=httpClient.execute(httpGet);

System.out.println(httpResponse.getStatusLine());

输出为:

HTTP/1.1200OK

利用HttpEntity获取请求到的网页的代码。

HttpEntity httpEntity=httpResponse.getEntity();

System.out.println(EntityUtils.toString(httpEntity));

输出为网页的源码(这里就不贴上了)。

3、处理报文头部

一个HTTP报文可以包含很多描述如内容长度,内容类型等信息属性的头部信息。

     获取给定类型的所有头部信息最有效方式是使用HeaderIterator接口。 依然使用上文中的httpResponse,

HeaderIterator it=httpResponse.headerIterator("Set-Cookie");//若不填参数则获取所有头部信息

while(it.hasNext()){         

          System.out.println(it.next());      

 }

输出为:

Set-Cookie:BAIDUID=E4886E9F68A9B5C677ECCF51027CE719:FG=1;expires=Thu,31-Dec-3723:55:55GMT;max-age=2147483647;path=/;domain=.baidu.comSet-Cookie:BIDUPSID=E4886E9F68A9B5C677ECCF51027CE719;expires=Thu,31-Dec-3723:55:55GMT;max-age=2147483647;path=/;domain=.baidu.comSet-Cookie:PSTM=1501480915;expires=Thu,31-Dec-3723:55:55GMT;max-age=2147483647;path=/;domain=.baidu.comSet-Cookie:BD_CK_SAM=1;path=/Set-Cookie:PSINO=2;domain=.baidu.com;path=/Set-Cookie:BDSVRTM=209;path=/Set-Cookie:H_PS_PSSID=1420_21116_17001_20928;path=/;domain=.baidu.com

它也提供解析HTTP报文到独立头部信息元素的方法。

HeaderElementIterator it=newBasicHeaderElementIterator(httpResponse.headerIterator("Set-Cookie"));

while(it.hasNext()){            

      HeaderElement headerElement=it.nextElement();            

       System.out.println(headerElement.getName()+" = "+headerElement.getValue());            

        NameValuePair[] pairs=headerElement.getParameters();

        for(NameValuePair nameValuePair :pairs){            

                      System.out.println("====="+nameValuePair);           

         }       

 }

输出为:

BAIDUID= AF97D9BAE560C06C0BD8233102267E05:FG=1expires=Thu31-Dec-3723:55:55GMT=nullmax-age=2147483647path=/domain=.baidu.com......

与上文输出对比一下可以发现,其实是获取每个"Set-Cookie"中的键值对。

4、HTTP实体

HTTP报文可以携带和请求或响应相关内容实体,实体可以在一些请求或响应找到,使用了实体的请求被称为是“封闭实体请求”,HTTP规范定义了两种封闭实体的方法:POST和PUT。对响应而言,通常包含一个内容实体。但也有特例。HttpClient根据其内容出自何处分为3种类型的实体:

Streamed 流式:内容在流中获取,或者在运行中产生,流式实体是不可重复生成的;

self-contained自我包含式:内容在内存中或通过独立的连接或其它实体中获得。自我包含式的实体是可以重复生成的。这种类型的实体会经常用于封闭HTTP请求的实体。

wrapping包装式:内容从另外一个实体中获得。

使用HTTP实体:

从实体类中读取内容,可以通过HttpEntity 的getContent 方法    从输入流中获取,返回一个java.io.InputSteam对象,或者提供一个输出流到HttpEntity的WriteTo(OutPutSteam)方法中,会返回所有写入到给定流中的内容。  当通过一个收到的报文获取实体时,HttpEntity的getContentType()方法和getContentLength()可以获取头部信息的Content-Type和Content-Length的信息。如果头部信息不可用,那么长度就返回-1,内容类型返回Null,如果头部信息可用,那么就会返回一个Header对象。

。。。。。

相关文章

网友评论

      本文标题:HttpClient 学习笔记(持续更新中)

      本文链接:https://www.haomeiwen.com/subject/btfwattx.html