首頁 >Java >java教程 >在 Android 上建立 HTTPS 連線時如何繞過不受信任的伺服器憑證?

在 Android 上建立 HTTPS 連線時如何繞過不受信任的伺服器憑證?

DDD
DDD原創
2024-12-10 16:25:12908瀏覽

How to Bypass Untrusted Server Certificates When Establishing HTTPS Connections on Android?

Android 上建立HTTPS 連線

嘗試在Android 上建立HTTPS 連線時,開發者可能會遇到與不受信任的伺服器證書相關的異常。為了解決這個問題,可以考慮接受伺服器憑證。

信任所有主機

繞過憑證驗證的一種方法是信任所有主機,從而有效地停用檢查。這可以透過實作自訂 HostnameVerifier 和 TrustManager 來實現。

// Hostname verifier that always returns true
HostnameVerifier DO_NOT_VERIFY = new HostnameVerifier() {
    @Override
    public boolean verify(String hostname, SSLSession session) {
        return true;
    }
};

// Trust manager that accepts all certificates
TrustManager[] trustAllCerts = new TrustManager[]{
    new X509TrustManager() {
        @Override
        public X509Certificate[] getAcceptedIssuers() {
            return new X509Certificate[]{};
        }

        @Override
        public void checkClientTrusted(X509Certificate[] chain, String authType) {}

        @Override
        public void checkServerTrusted(X509Certificate[] chain, String authType) {}
    }
};

接下來,初始化 SSLContext 並套用信任管理員和主機名稱驗證器。

SSLContext sc = SSLContext.getInstance("TLS");
sc.init(null, trustAllCerts, new SecureRandom());
HttpsURLConnection.setDefaultSSLSocketFactory(sc.getSocketFactory());

範例用法

建立 HTTP 連接時,檢查協議,如果是則應用上述配置HTTPS。

HttpURLConnection http = null;
String url = "https://example.com";

if (url.toLowerCase().equals("https")) {
    trustAllHosts();
    HttpsURLConnection https = (HttpsURLConnection) url.openConnection();
    https.setHostnameVerifier(DO_NOT_VERIFY);
    http = https;
} else {
    http = (HttpURLConnection) url.openConnection();
}

以上是在 Android 上建立 HTTPS 連線時如何繞過不受信任的伺服器憑證?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn