Glide做https認(rèn)證:

一、Glide基本使用
在Android中,加載圖片最好用的就是Glide了,至于為什么呢,不多說,Google都推薦了,Google的很多官方Demo都是用Glide加載網(wǎng)絡(luò)圖片的。

Glide使用步驟如下:

使用AndroidStudio創(chuàng)建一個(gè)GlideDemo項(xiàng)目,選擇Kotlin語言

添加Glide依賴

implementation 'com.github.bumptech.glide:glide:4.11.0'

添加權(quán)限

<uses-permission android:name="android.permission.INTERNET"/>
<uses-permission android:name="android.permission.ACCESS_NETWORK_STATE"/>
<uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE"/>
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"/>

使用Glide加載圖片

class MainActivity : AppCompatActivity() {
    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
        setContentView(R.layout.activity_main)
        Glide.with(this)
                .load("http://192.168.1.250:8080/cat.jpg")
                .centerCrop()
                .placeholder(R.mipmap.ic_launcher)
                .into(imageView)
    }
}

OK,就是這么簡單就完成了圖片的加載,上面Glide中各函數(shù)的功能大家如果不懂的話去官網(wǎng)看一下就知道了,這里不多解釋。本篇文章主要是講加載https的圖片。

二、加載Https圖片
使用上面的代碼去加載一些網(wǎng)絡(luò)上的https圖片一般是沒有問題的,沒問題是因?yàn)榫W(wǎng)絡(luò)上的https使用的證書一般是權(quán)威機(jī)構(gòu)頒發(fā)的證書,而這些權(quán)威機(jī)構(gòu)的根證書在手機(jī)出廠時(shí)就已經(jīng)預(yù)裝在手機(jī)里面了,所以我們加載https圖片時(shí)會(huì)自動(dòng)完成認(rèn)證,但是突然有一天,我們公司的網(wǎng)絡(luò)請(qǐng)求也改成了Https了,用的是自定義證書,并不是權(quán)威機(jī)構(gòu)頒發(fā)的,所以這個(gè)時(shí)候加載公司的https的圖片時(shí)就加載失敗了,異常如下:

Glide: Load failed for https://192.168.1.250:8080/cat.jpg with size [1080x162]
class com.bumptech.glide.load.engine.GlideException: Failed to load resource
There was 1 cause:
javax.net.ssl.SSLHandshakeException(java.security.cert.CertPathValidatorException: Trust anchor for certification path not found.)

看到CertPathValidatorException(證書路徑驗(yàn)證器異常)不用我多說應(yīng)該也知道是什么原理導(dǎo)致的了。

在服務(wù)器改成https請(qǐng)求的時(shí)候,我是先處理的普通請(qǐng)求,比如登錄請(qǐng)求,這些請(qǐng)求都是使用OkHttp實(shí)現(xiàn)的,所以我開始時(shí)找OkHttp配置自定義證書的實(shí)現(xiàn),而且也實(shí)現(xiàn)了,所以這里只講怎么設(shè)置讓Glide使用OkHttp來下載圖片,而且是使用我們配置過的(即設(shè)置好自定證書的)OkHttp對(duì)象來下載圖片。當(dāng)然,如果你用的是其它的網(wǎng)絡(luò)請(qǐng)求框架,如果該網(wǎng)絡(luò)請(qǐng)求框架也被Glide支持的話,則也可以參考我這個(gè)文章來集成的。

剛開始我百度找答案,答案是有,但是寫的很不清楚,于是只能靠自己了,去Glide官網(wǎng)找答案,這里記錄一下,希望對(duì)大家有所幫助,集成OkHttp步驟如下:

添加Glide中的更多依賴

// OkHttp網(wǎng)絡(luò)請(qǐng)求庫
implementation 'com.squareup.okhttp3:okhttp:4.8.1'
// Glide圖片加載庫
implementation 'com.github.bumptech.glide:glide:4.11.0'
// Glide集成OkHttp時(shí)需要使用的庫
implementation "com.github.bumptech.glide:okhttp3-integration:4.11.0"
// Glide需要處理注解時(shí)的依賴庫,用于處理注解并生成java類
kapt 'com.github.bumptech.glide:compiler:4.11.0'

上面的依賴中使用到了注解處理,所以還需要添加注解處理器插件,添加在gradle文件的最前面的位置:

apply plugin: 'kotlin-kapt' 

創(chuàng)建一個(gè)類繼承AppGlideModule,這個(gè)類名可以隨意,如下:

@GlideModule
class OkHttpGlideModule : AppGlideModule() {
    override fun registerComponents(context: Context, glide: Glide, registry: Registry) {
        val okHttpClient = OkHttpClient.Builder().build()
        registry.replace(GlideUrl::class.java, InputStream::class.java, OkHttpUrlLoader.Factory(okHttpClient))
    }
} 

網(wǎng)絡(luò)百度的那些答案這一步是各種覆蓋各種類,其實(shí)根本就不用,我們自己創(chuàng)建一個(gè)OkHttp對(duì)象傳給Glide即可,這樣Glide就會(huì)使用我們創(chuàng)建的OkHttp對(duì)象來下載圖片了,對(duì)于具體怎么配置OkHttp可以接受自定義證書,請(qǐng)看我的這篇文章,為了完整性,這里簡單實(shí)現(xiàn)一個(gè)忽略所有證書的實(shí)現(xiàn)代碼如下:

@GlideModule
class OkHttpGlideModule : AppGlideModule() { 
    override fun registerComponents(context: Context, glide: Glide, registry: Registry) {
        val builder = OkHttpClient.Builder()
        builder.sslSocketFactory(sSLSocketFactory, trustManager)
        val okHttpClient = builder.build()
        registry.replace(GlideUrl::class.java, InputStream::class.java, OkHttpUrlLoader.Factory(okHttpClient))
    }
    
    /** 獲取一個(gè)SSLSocketFactory */
    val sSLSocketFactory: SSLSocketFactory
        get() = try {
            val sslContext = SSLContext.getInstance("SSL")
            sslContext.init(null, arrayOf(trustManager), SecureRandom())
            sslContext.socketFactory
        } catch (e: Exception) {
            throw RuntimeException(e)
        }

    /** 獲取一個(gè)忽略證書的X509TrustManager */
    val trustManager: X509TrustManager
        get() = object : X509TrustManager {
            override fun checkClientTrusted(chain: Array<X509Certificate>, authType: String) { }    
            override fun checkServerTrusted(chain: Array<X509Certificate>, authType: String) { }    
            override fun getAcceptedIssuers(): Array<X509Certificate> { return arrayOf() }
        }
} 

最后還有一步,第2步創(chuàng)建的類中使用了注解,Glide會(huì)自動(dòng)生成一個(gè)GlideApp的類,這個(gè)類就是使用了我們配置的OkHttp的,所以在下載圖片時(shí),我們要使用GlideApp來代替之前的Glide類,如下:

GlideApp.with(this)
                .load("https://192.168.1.250:8080/cat.jpg")
                .centerCrop()
                .placeholder(R.mipmap.ic_launcher)
                .into(imageView) 
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容