HttpClient 學習筆記(持續更新中)

本文是博主在實習階段所接觸到的業務中所學到的關于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對象。

。。。。。

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。

推薦閱讀更多精彩內容