本文是博主在实习阶段所接触到的业务中所学到的关于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对象。
。。。。。