|
|
|
@ -1,5 +1,6 @@ |
|
|
|
|
package io.legado.app.help.http |
|
|
|
|
|
|
|
|
|
import android.annotation.SuppressLint |
|
|
|
|
import java.io.IOException |
|
|
|
|
import java.io.InputStream |
|
|
|
|
import java.security.KeyManagementException |
|
|
|
@ -21,10 +22,12 @@ object SSLHelper { |
|
|
|
|
* 这是一种有很大安全漏洞的办法 |
|
|
|
|
*/ |
|
|
|
|
val unsafeTrustManager: X509TrustManager = object : X509TrustManager { |
|
|
|
|
@SuppressLint("TrustAllX509TrustManager") |
|
|
|
|
@Throws(CertificateException::class) |
|
|
|
|
override fun checkClientTrusted(chain: Array<X509Certificate>, authType: String) { |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
@SuppressLint("TrustAllX509TrustManager") |
|
|
|
|
@Throws(CertificateException::class) |
|
|
|
|
override fun checkServerTrusted(chain: Array<X509Certificate>, authType: String) { |
|
|
|
|
} |
|
|
|
@ -34,12 +37,11 @@ object SSLHelper { |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
val unsafeSSLSocketFactory: SSLSocketFactory |
|
|
|
|
get() { |
|
|
|
|
val unsafeSSLSocketFactory: SSLSocketFactory by lazy { |
|
|
|
|
try { |
|
|
|
|
val sslContext = SSLContext.getInstance("SSL") |
|
|
|
|
sslContext.init(null, arrayOf(unsafeTrustManager), SecureRandom()) |
|
|
|
|
return sslContext.socketFactory |
|
|
|
|
sslContext.socketFactory |
|
|
|
|
} catch (e: Exception) { |
|
|
|
|
throw RuntimeException(e) |
|
|
|
|
} |
|
|
|
|