最近公司因安全问题,网络切换到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)