實現一個簡單的網絡框架之配置篇

實現網絡基本配置

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執(zhí)行請求時為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請求的區(qū)別?

HTTPS并非是應用層的一種新協(xié)議。只是HTTP通信接口部分用SLL和TLS協(xié)議代替而已。通常,HTTP直接和TCP通信,當使用SSL時,演變成先和SSL通信,再由SSL和TCP通信。簡而言之,所謂HTTPS,其實就是身披SSL協(xié)議的這層外殼的HTTP。

因此,針對Https請求,我們提供了一個設置SSL的接口來實現對其進行不同的設置。

HttpUrlConnConfig的實現

/**
 * Created by lq on 2017/5/14.
 * 這是針對使用HttpUrlStack執(zhí)行請求時為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忽略證書的方式。

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
【社區(qū)內容提示】社區(qū)部分內容疑似由AI輔助生成,瀏覽時請結合常識與多方信息審慎甄別。
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發(fā)布,文章內容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務。

相關閱讀更多精彩內容

友情鏈接更多精彩內容