Trust Anchor not found for Android SSL Connection

后端 未结 17 1074
囚心锁ツ
囚心锁ツ 2020-11-22 05:06

I am trying to connect to an IIS6 box running a godaddy 256bit SSL cert, and I am getting the error :

java.security.cert.CertPathValidatorException: Trust an         


        
17条回答
  •  萌比男神i
    2020-11-22 05:34

    Use https://www.ssllabs.com/ssltest/ to test a domain.

    The solution of Shihab Uddin in Kotlin.

    import java.security.SecureRandom
    import java.security.cert.X509Certificate
    import javax.net.ssl.*
    import javax.security.cert.CertificateException
    
    object {
    
        val okHttpClient: OkHttpClient
        val gson: Gson
        val retrofit: Retrofit
    
        init {
    
            okHttpClient = getOkHttpBuilder()
                // Other parameters like connectTimeout(15, TimeUnit.SECONDS)
                .build()
    
            gson = GsonBuilder().setLenient().create()
    
            retrofit = Retrofit.Builder()
                .baseUrl(BASE_URL)
                .client(okHttpClient)
                .addConverterFactory(GsonConverterFactory.create(gson))
                .build()
        }
    
        fun getOkHttpBuilder(): OkHttpClient.Builder =
            if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.M) {
                OkHttpClient().newBuilder()
            } else {
                // Workaround for the error "Caused by: com.android.org.bouncycastle.jce.exception.ExtCertPathValidatorException: Could not validate certificate: Certificate expired at".
                getUnsafeOkHttpClient()
            }
    
        private fun getUnsafeOkHttpClient(): OkHttpClient.Builder =
            try {
                // Create a trust manager that does not validate certificate chains
                val trustAllCerts: Array = arrayOf(
                    object : X509TrustManager {
                        @Throws(CertificateException::class)
                        override fun checkClientTrusted(chain: Array?,
                                                        authType: String?) = Unit
    
                        @Throws(CertificateException::class)
                        override fun checkServerTrusted(chain: Array?,
                                                        authType: String?) = Unit
    
                        override fun getAcceptedIssuers(): Array = arrayOf()
                    }
                )
                // Install the all-trusting trust manager
                val sslContext: SSLContext = SSLContext.getInstance("SSL")
                sslContext.init(null, trustAllCerts, SecureRandom())
                // Create an ssl socket factory with our all-trusting manager
                val sslSocketFactory: SSLSocketFactory = sslContext.socketFactory
                val builder = OkHttpClient.Builder()
                builder.sslSocketFactory(sslSocketFactory,
                    trustAllCerts[0] as X509TrustManager)
                builder.hostnameVerifier { _, _ -> true }
                builder
            } catch (e: Exception) {
                throw RuntimeException(e)
            }
    }
    

    The same error will also appear if you use Glide, images won't show. To overcome it see Glide - javax.net.ssl.SSLHandshakeException: java.security.cert.CertPathValidatorException: Trust anchor for certification path not found and How to set OkHttpClient for glide.

    @GlideModule
    class MyAppGlideModule : AppGlideModule() {
    
        val okHttpClient = Api.getOkHttpBuilder().build() // Api is the class written above.
        // It is better to create okHttpClient here and not use Api.okHttpClient,
        // because their settings may differ. For instance, it can use its own
        // `addInterceptor` and `addNetworkInterceptor` that can affect on a read JSON.
    
    
        override fun registerComponents(context: Context, glide: Glide, registry: Registry) {
            registry.replace(GlideUrl::class.java, InputStream::class.java,
                OkHttpUrlLoader.Factory(okHttpClient))
        }
    }
    

    build.gradle:

    // Glide.
    implementation 'com.github.bumptech.glide:glide:4.11.0'
    implementation 'com.github.bumptech.glide:okhttp3-integration:4.11.0'
    kapt 'com.github.bumptech.glide:compiler:4.11.0'
    

提交回复
热议问题