編輯:關於Android編程
HTTP 頭處理
HTTP 頭是 HTTP 請求和響應中的重要組成部分。在創建 HTTP 請求時需要設置一些 HTTP 頭。在得到 HTTP 的響應之後,也會需要對其中包含的 HTTP 頭進行解析。從代碼的角度來說,HTTP 頭的數據結構是 Map<String, List<String>>類型。也就是說,對於每個 HTTP 頭,可能有多個值。但是大部分 HTTP 頭都只有一個值,只有少部分 HTTP 頭允許多個值。OkHttp 采用了簡單的方式來區分這兩種類型,使得對 HTTP 頭的使用更加簡單。
在設置 HTTP 頭時,使用 header(name, value) 方法來設置 HTTP 頭的唯一值。對同一個 HTTP 頭,多次調用該方法會覆蓋之前設置的值。使用 addHeader(name, value) 方法來為 HTTP 頭添加新的值。在讀取 HTTP 頭時,使用 header(name) 方法來讀取 HTTP 頭的最近出現的值。如果該 HTTP 頭只有單個值,則返回該值;如果有多個值,則返回最後一個值。使用 headers(name) 方法來讀取 HTTP 頭的所有值。
下面的代碼中使用 header 方法設置了 User-Agent 頭的值,並添加了一個 Accept 頭的值。在進行解析時,通過 header 方法來獲取 Server 頭的單個值,通過 headers 方法來獲取 Set-Cookie 頭的所有值。
public class Headers { public static void main(String[] args) throws IOException { OkHttpClient client = new OkHttpClient(); Request request = new Request.Builder() .url("http://www.baidu.com") .header("User-Agent", "My super agent") .addHeader("Accept", "text/html") .build(); Response response = client.newCall(request).execute(); if (!response.isSuccessful()) { throw new IOException("服務器端錯誤: " + response); } System.out.println(response.header("Server")); System.out.println(response.headers("Set-Cookie")); } }
Synchronous Get(同步 GET)
下載一個文件,以字符串的形式打印出他的頭部信息,打印出響應數據體信息。
String() 方法作為一些小文件的響應數據體是非常方便和高效的。但是如果針對一些大文件的下載(大於 1MB 文件),盡量避免使用 String() 方法因為他會將整個文本加載到內存中。針對這種例子優先選擇的解決方案是將數據體作為一個數據流來處理。
private final OkHttpClient client = new OkHttpClient(); public void run() throws Exception { Request request = new Request.Builder() .url("http://publicobject.com/helloworld.txt") .build(); Response response = client.newCall(request).execute(); if (!response.isSuccessful()) throw new IOException("Unexpected code " + response); Headers responseHeaders = response.headers(); for (int i = 0; i < responseHeaders.size(); i++) { System.out.println(responseHeaders.name(i) + ": " + responseHeaders.value(i)); } System.out.println(response.body().string()); }
Asynchronous Get(異步 GET)
在工作線程中進行下載任務,並且在響應到達的時候采用回調的方式通知。這個回調會等待響應信息頭准備好之後發送,讀取這個響應頭信息仍然會阻塞。目前的 OKHttp 不支持異步的 APIS 來接收處理部分的響應體。
private final OkHttpClient client = new OkHttpClient(); public void run() throws Exception { Request request = new Request.Builder() .url("http://publicobject.com/helloworld.txt") .build(); client.newCall(request).enqueue(new Callback() { @Override public void onFailure(Request request, IOException throwable) { throwable.printStackTrace(); } @Override public void onResponse(Response response) throws IOException { if (!response.isSuccessful()) throw new IOException("Unexpected code " + response); Headers responseHeaders = response.headers(); for (int i = 0; i < responseHeaders.size(); i++) { System.out.println(responseHeaders.name(i) + ": " + responseHeaders.value(i)); } System.out.println(response.body().string()); } }); }
本文實例講述了Android4.X中SIM卡信息初始化過程詳解。分享給大家供大家參考,具體如下:Phone 對象初始化的過程中,會加載SIM卡的部分數據信息,這些信息會保
一:新建HelloEditText工程創建設置如下:Project name:HelloEditText Build Target :android 2.2 Applic
ViewFlipper和ViewPager挺像的,都是一個view容器。內部可以添加多個view,只是viewpager可以通過左右滑動來切換view,而viewFlip
最近學習了WebView組件,寫了一個有道詞典的小案例,分享給大家,供大家參考,具體內容如下效果圖:源碼下載:https://coding.net/u/gxs1225/p