在
Android開發中咱們常常會用到網絡鏈接功能與服務器進行數據的交互,爲此Android的SDK提供了Apache的
HttpClient來方便咱們使用各類Http服務。你能夠把
HttpClient想象成一個瀏覽器,經過它的API咱們能夠很方便的發出GET,POST請求(固然它的功能遠不止這些)。
好比你只需如下幾行代碼就能發出一個簡單的GET請求並打印響應結果:
java代碼:
- try {
- // 建立一個默認的HttpClient
- HttpClient httpclient = new DefaultHttpClient();
- // 建立一個GET請求
- HttpGet request = new HttpGet("www.google.com");
- // 發送GET請求,並將響應內容轉換成字符串
- String response = httpclient.execute(request, new BasicResponseHandler());
- Log.v("response text", response);
- } catch (ClientProtocolException e) {
- e.printStackTrace();
- } catch (IOException e) {
- e.printStackTrace();
- }
-
-
複製代碼
爲何要使用單例HttpClient
?
這只是一段演示代碼,實際的項目中的請求與響應處理會複雜一些,而且還要考慮到代碼的容錯性,可是這並非本篇的重點。注意代碼的第三行:
HttpClient httpclient = new DefaultHttpClient();
在發出HTTP請求前,咱們先建立了一個HttpClient對象。那麼,在實際項目中,咱們極可能在多處須要進行HTTP通訊, 這時候咱們不須要爲每一個請求都建立一個新的HttpClient。由於以前已經提到,HttpClient就像一個小型的瀏覽器,對於整個應用,咱們只需 要一個HttpClient就夠了。看到這裏,必定有人內心想,這有什麼難的,用單例啊!!就像這樣:
java代碼:
- public class CustomerHttpClient {
- private static HttpClient customerHttpClient;
-
- private CustomerHttpClient() {
- }
-
- public static HttpClient getHttpClient() {
- if(null == customerHttpClient) {
- customerHttpClient = new DefaultHttpClient();
- }
- return customerHttpClient;
- }
- }
-
-
複製代碼
多線程!試想,如今咱們的應用程序使用同一個
HttpClient來管理全部的Http請求,一旦出現 併發請求,那麼必定會出現多線程的問題。這就好像咱們的瀏覽器只有一個標籤頁卻有多個用戶,A要上google,B要上baidu,這時瀏覽器就會忙不過 來了。幸運的是,HttpClient提供了建立線程安全對象的API,幫助咱們能很快地獲得線程安全的「瀏覽器」。
解決多線程問題
java代碼:
- public class CustomerHttpClient {
- private static final String CHARSET = HTTP.UTF_8;
- private static HttpClient customerHttpClient;
-
- private CustomerHttpClient() {
- }
-
- public static synchronized HttpClient getHttpClient() {
- if (null == customerHttpClient) {
- HttpParams params = new BasicHttpParams();
- // 設置一些基本參數
- HttpProtocolParams.setVersion(params, HttpVersion.HTTP_1_1);
- HttpProtocolParams.setContentCharset(params,CHARSET);
- HttpProtocolParams.setUseExpectContinue(params, true);
- HttpProtocolParams.setUserAgent(
- params,"Mozilla/5.0(Linux;U;Android 2.2.1;en-us;Nexus One Build.FRG83) "
- + "AppleWebKit/553.1(KHTML,like Gecko) Version/4.0 Mobile Safari/533.1");
- // 超時設置
- /* 從鏈接池中取鏈接的超時時間 */
- ConnManagerParams.setTimeout(params, 1000);
- /* 鏈接超時 */
- HttpConnectionParams.setConnectionTimeout(params, 2000);
- /* 請求超時 */
- HttpConnectionParams.setSoTimeout(params, 4000);
-
- // 設置咱們的HttpClient支持HTTP和HTTPS兩種模式
- SchemeRegistry schReg = new SchemeRegistry();
- schReg.register(new Scheme("http", PlainSocketFactory.getSocketFactory(), 80));
- schReg.register(new Scheme("https", SSLSocketFactory.getSocketFactory(), 443));
-
- // 使用線程安全的鏈接管理來建立HttpClient
- ClientConnectionManager conMgr = new ThreadSafeClientConnManager(params, schReg);
- customerHttpClient = new DefaultHttpClient(conMgr, params);
- }
- return customerHttpClient;
- }
- }
-
-
複製代碼
在上面的getHttpClient()方法中,咱們爲HttpClient配置了一些基本參數和超時設置,而後使用ThreadSafeClientConnManager來建立線程安全的HttpClient。上面的代碼提到了3種超時設置,比較容易搞混,故在此特做辨析。 java
在Android開發中咱們常常會用到網絡鏈接功能與服務器進行數據的交互,爲此Android的SDK提供了Apache的HttpClient來方便咱們使用各類Http服務。你能夠把HttpClient想象成一個瀏覽器,經過它的API咱們能夠很方便的發出GET,POST請求(固然它的功能遠不止這些)。
好比你只需如下幾行代碼就能發出一個簡單的GET請求並打印響應結果:
java代碼:
android
- try {
- // 建立一個默認的HttpClient
- HttpClient httpclient = new DefaultHttpClient();
- // 建立一個GET請求
- HttpGet request = new HttpGet("www.google.com");
- // 發送GET請求,並將響應內容轉換成字符串
- String response = httpclient.execute(request, new BasicResponseHandler());
- Log.v("response text", response);
- } catch (ClientProtocolException e) {
- e.printStackTrace();
- } catch (IOException e) {
- e.printStackTrace();
- }
-
-
複製代碼
爲何要使用單例HttpClient
?
這只是一段演示代碼,實際的項目中的請求與響應處理會複雜一些,而且還要考慮到代碼的容錯性,可是這並非本篇的重點。注意代碼的第三行:
HttpClient httpclient = new DefaultHttpClient();
在發出HTTP請求前,咱們先建立了一個HttpClient對象。那麼,在實際項目中,咱們極可能在多處須要進行HTTP通訊, 這時候咱們不須要爲每一個請求都建立一個新的HttpClient。由於以前已經提到,HttpClient就像一個小型的瀏覽器,對於整個應用,咱們只需 要一個HttpClient就夠了。看到這裏,必定有人內心想,這有什麼難的,用單例啊!!就像這樣:
java代碼:
- public class CustomerHttpClient {
- private static HttpClient customerHttpClient;
-
- private CustomerHttpClient() {
- }
-
- public static HttpClient getHttpClient() {
- if(null == customerHttpClient) {
- customerHttpClient = new DefaultHttpClient();
- }
- return customerHttpClient;
- }
- }
-
-
複製代碼
多線程!試想,如今咱們的應用程序使用同一個
HttpClient來管理全部的Http請求,一旦出現 併發請求,那麼必定會出現多線程的問題。這就好像咱們的瀏覽器只有一個標籤頁卻有多個用戶,A要上google,B要上baidu,這時瀏覽器就會忙不過 來了。幸運的是,HttpClient提供了建立線程安全對象的API,幫助咱們能很快地獲得線程安全的「瀏覽器」。
解決多線程問題
java代碼:
- public class CustomerHttpClient {
- private static final String CHARSET = HTTP.UTF_8;
- private static HttpClient customerHttpClient;
-
- private CustomerHttpClient() {
- }
-
- public static synchronized HttpClient getHttpClient() {
- if (null == customerHttpClient) {
- HttpParams params = new BasicHttpParams();
- // 設置一些基本參數
- HttpProtocolParams.setVersion(params, HttpVersion.HTTP_1_1);
- HttpProtocolParams.setContentCharset(params,CHARSET);
- HttpProtocolParams.setUseExpectContinue(params, true);
- HttpProtocolParams.setUserAgent(
- params,"Mozilla/5.0(Linux;U;Android 2.2.1;en-us;Nexus One Build.FRG83) "
- + "AppleWebKit/553.1(KHTML,like Gecko) Version/4.0 Mobile Safari/533.1");
- // 超時設置
- /* 從鏈接池中取鏈接的超時時間 */
- ConnManagerParams.setTimeout(params, 1000);
- /* 鏈接超時 */
- HttpConnectionParams.setConnectionTimeout(params, 2000);
- /* 請求超時 */
- HttpConnectionParams.setSoTimeout(params, 4000);
-
- // 設置咱們的HttpClient支持HTTP和HTTPS兩種模式
- SchemeRegistry schReg = new SchemeRegistry();
- schReg.register(new Scheme("http", PlainSocketFactory.getSocketFactory(), 80));
- schReg.register(new Scheme("https", SSLSocketFactory.getSocketFactory(), 443));
-
- // 使用線程安全的鏈接管理來建立HttpClient
- ClientConnectionManager conMgr = new ThreadSafeClientConnManager(params, schReg);
- customerHttpClient = new DefaultHttpClient(conMgr, params);
- }
- return customerHttpClient;
- }
- }
-
-
複製代碼
在上面的
getHttpClient()方法中,咱們爲HttpClient配置了一些基本參數和超時設置,而後使用
ThreadSafeClientConnManager來建立線程安全的HttpClient。上面的代碼提到了3種超時設置,比較容易搞混,故在此特做辨析。