Android Glide加载需要Https双向认证的图片

最近公司因安全问题,网络切换到https,由于使用的是自定义证书,而并非权威机构证书,所以在加载图片时无法正常显示,然后查看Glide源码,了解到Glide内部网络加载使用的是HttpURLConnection,相较我们经常使用的Okhttp性能上差距较大,所以我们能否使用Okhttp替换网络组件。

实际上官方的Okhttp集成库,已经实现了上面的代码OkHttpLibraryGlideModule,我们只需要引入依赖即可。

public final class OkHttpLibraryGlideModule extends LibraryGlideModule {
  @Override
  public void registerComponents(
      @NonNull Context context, @NonNull Glide glide, @NonNull Registry registry) {
    registry.replace(GlideUrl.class, InputStream.class, new OkHttpUrlLoader.Factory());
  }
}
1.Glide官方的Okhttp官方扩展库和处理注解时的依赖库

首先在AndroidManifest清单文件中添加

<meta-data
            android:name=".HttpsGlideModule "
            android:value="AppGlideModule" />

在build.gradle文件中添加注解处理器插件

    id 'kotlin-kapt'

然后添加依赖库

	//Glide官方扩展库,https://github.com/bumptech/glide/tree/master/integration/okhttp3
    implementation "com.github.bumptech.glide:okhttp3-integration:4.11.0"
    
 	// Glide需要处理注解时的依赖库,用于处理注解并生成java类
    kapt 'com.github.bumptech.glide:compiler:4.11.0'
2.应用模块中继承AppGlideModule实现,并实现Okhttp的双向认证。
@GlideModule
class HttpsGlideModule : AppGlideModule() {

    var sslSocketFactory = MySSLSocketFactory.getSocketFactory(MyApplication.instance)
    
    override fun registerComponents(context: Context, glide: Glide, registry: Registry) {
        val builder = OkHttpClient.Builder()
        builder.sslSocketFactory(sslSocketFactory)
        val okHttpClient = builder.build()
        registry.replace(
            GlideUrl::class.java,
            InputStream::class.java,
            OkHttpUrlLoader.Factory(okHttpClient)
        )
    }
}
3.由于我们在HttpsGlideModule类中使用了注解,所以 Glide会自动生成一个GlideApp的类,这个类就是使用了我们配置的OkHttp的,调用方法如下:
GlideApp.with(this)
                .load(url)
                .into(imageView) 
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

踏着蜗牛去旅行

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值