實現網絡基本配置
1. 我們定義一個抽象類HttpConfig
public abstract class HttpConfig {
//設置默認代理
public String userAgent = "default";
//設置默認讀取時間
public int soTimeOut = 10000;
//設置默認連接時間
public int ConnTimeOut = 10000;
}
2. 實現具體的HttpClientConfig和HttpUrlConnConfig
- 疑點:為什么這里需要對設置進行劃分?
因為我們選擇在SDK小于9的情況下,選擇使用HttpClient,而當SDK大于或等于9時,選擇使用HttpURLConnection。
- 疑點:為什么需要對其進行劃分呢?
我們知道Android Framework里面同時包含HttpURLConnection和Apache HTTP Client 2套Http框架,HttpURLConnection相對輕量級,也比較小,而Apache HTTP Client接口多,比較大,HttpURLConnection是最佳選擇,但在Android SDK小于9時,HttpURLConnection存在一些bug,所以當Android SDK小于9時,使用HttpClient,否則使用HttpURLConnection。
HttpClientConfig的實現
/**
* Created by lq on 2017/5/14.
* 這是針對使用HttpClientStack執行請求時為https請求配置的SSLSocketFactory類
*/
public class HttpClientConfig extends HttpConfig {
private static HttpClientConfig sConfig = new HttpClientConfig();
private SSLSocketFactory mSslSocketFactory;
private HttpClientConfig(){
}
public static HttpClientConfig getConfig(){
return sConfig;
}
//配置https請求的SSLSocketFactory
public void setHttpsConfig(SSLSocketFactory sslSocketFactory){
mSslSocketFactory = sslSocketFactory;
}
public SSLSocketFactory getSslSocketFactory(){
return mSslSocketFactory;
}
}
- 疑點:http請求與https請求的區別?
HTTPS并非是應用層的一種新協議。只是HTTP通信接口部分用SLL和TLS協議代替而已。通常,HTTP直接和TCP通信,當使用SSL時,演變成先和SSL通信,再由SSL和TCP通信。簡而言之,所謂HTTPS,其實就是身披SSL協議的這層外殼的HTTP。
因此,針對Https請求,我們提供了一個設置SSL的接口來實現對其進行不同的設置。
HttpUrlConnConfig的實現
/**
* Created by lq on 2017/5/14.
* 這是針對使用HttpUrlStack執行請求時為https請求設置的SSLSocketFactory和HostnameVerifier的配置類
*/
public class HttpUrlConnConfig extends HttpConfig {
private static HttpUrlConnConfig sConfig = new HttpUrlConnConfig();
private SSLSocketFactory mSslSocketFactory = null;
private HostnameVerifier mHostnameVerifier = null;
private HttpUrlConnConfig(){
}
public static HttpUrlConnConfig getConfig(){
return sConfig;
}
//配置https請求的SSLSocketFactory與HostnameVerifier
public void setHttpsConfig(SSLSocketFactory sslSocketFactory,
HostnameVerifier hostnameVerifier){
mSslSocketFactory = sslSocketFactory;
mHostnameVerifier = hostnameVerifier;
}
public HostnameVerifier getHostnameVerifier(){
return mHostnameVerifier;
}
public SSLSocketFactory getSslSocketFactory() {
return mSslSocketFactory;
}
}
- 疑問:HostnameVerifier是一個什么配置?
這是一個用于主機名驗證的基接口。在握手期間,如果URL的主機名和服務器的標識主機名不匹配,則驗證機制可以回調此接口實現的程序來判斷是否允許此連接。
- 疑問:為什么在HttpClientConfig中沒有此配置?
實際上是因為我們采取了HttpClient忽略證書的方式。