首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Glide V4加载https图像

Glide V4加载https图像
EN

Stack Overflow用户
提问于 2018-03-29 21:15:28
回答 3查看 10.1K关注 0票数 6

我知道这个link,并尝试了,但这是为滑动V3解决方案,我需要加载https://myimage/image/xxx.png但滑动抛出异常

代码语言:javascript
复制
FileNotFoundException(No content provider)** and **SSLHandshakeException: java.security.cert.CertPathValidatorException: Trust anchor for certification path not found

我使用的是4.5.0版本的Glide,我花了很多时间,但找不到任何解决方案,任何帮助都将不胜感激。

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2018-03-30 15:06:20

我挣扎了近1天,但找到解决方案,如果你是使用ssl认证的链接,如https,那么你需要添加两个更多的滑动依赖,所以你必须添加这个

代码语言:javascript
复制
implementation 'com.github.bumptech.glide:annotations:4.5.0'
kapt 'com.github.bumptech.glide:compiler:4.5.0'

我正在使用kotlin,这就是为什么我添加了kapt你可以使用kotlin。

之后,您需要在项目中创建GlideModule,因此以下是Glide V4的代码

代码语言:javascript
复制
 @GlideModule
public class MyGlideModule extends AppGlideModule {

    @Override
    public void applyOptions(Context context, GlideBuilder builder) {
        super.applyOptions(context, builder);
    }

    @Override
    public void registerComponents(@NonNull Context context, @NonNull Glide glide, @NonNull Registry registry) {
        OkHttpClient okHttpClient= UnsafeOkHttpClient.getUnsafeOkHttpClient();
        registry.replace(GlideUrl.class, InputStream.class, new OkHttpUrlLoader.Factory(okHttpClient));
    }
}

这里我们绕过了ssl,所以这里是UnsafeOkHttpClient类。

代码语言:javascript
复制
    public class UnsafeOkHttpClient {


    public static OkHttpClient getUnsafeOkHttpClient() {
        try {
            // Create a trust manager that does not validate certificate chains
            final TrustManager[] trustAllCerts = new TrustManager[] {
                    new X509TrustManager() {
                        @Override
                        public void checkClientTrusted(java.security.cert.X509Certificate[] chain, String authType) throws CertificateException {
                        }

                        @Override
                        public void checkServerTrusted(java.security.cert.X509Certificate[] chain, String authType) throws CertificateException {
                        }

                        @Override
                        public java.security.cert.X509Certificate[] getAcceptedIssuers() {
                            return new java.security.cert.X509Certificate[]{};
                        }
                    }
            };

            // Install the all-trusting trust manager
            final SSLContext sslContext = SSLContext.getInstance("SSL");
            sslContext.init(null, trustAllCerts, new java.security.SecureRandom());

            // Create an ssl socket factory with our all-trusting manager
            final SSLSocketFactory sslSocketFactory = sslContext.getSocketFactory();

            OkHttpClient.Builder builder = new OkHttpClient.Builder();
            builder.sslSocketFactory(sslSocketFactory, (X509TrustManager)trustAllCerts[0]);
            builder.hostnameVerifier(new HostnameVerifier() {
                @Override
                public boolean verify(String hostname, SSLSession session) {
                    return true;
                }
            });

            OkHttpClient okHttpClient = builder.build();
            return okHttpClient;
        } catch (Exception e) {
            throw new RuntimeException(e);
        }
    }
 }

之后,您还需要两个类OkHttpUrlLoader和OkHttpStreamFetcher

你可以从Glide Link复制过去

在最后一步之后,我不知道这就是为什么需要一天的时间,所以你需要构建项目和Glide将生成GlideApp类,所以你需要使用GlideApp类来显示图像HTTPS,如下所示:

代码语言:javascript
复制
GlideApp.with(context).load(url).apply(RequestOptions.circleCropTransform()).into(imageView)

我认为这对其他正在遭受这类问题的人来说是非常有帮助的。保留代码:)

票数 9
EN

Stack Overflow用户

发布于 2018-07-30 17:39:08

Mohit答案的结构运行良好,但是现在您可以获取所有必需的类here,因此要包含它们只需添加

代码语言:javascript
复制
implementation "com.github.bumptech.glide:okhttp3-integration:$glideV"
票数 2
EN

Stack Overflow用户

发布于 2019-01-15 12:43:59

这个解决方案来自我的实现‘com.github.umptech.glide:glide:4.8.0’

在扩展应用程序中添加

代码语言:javascript
复制
SSLContext mySSLContext = SSLContext.getInstance("TLS");
TrustManager[] trustAllCerts = new TrustManager[]{new X509TrustManager() {
public java.security.cert.X509Certificate[] getAcceptedIssuers() {
return new java.security.cert.X509Certificate[]{};
}

public void checkClientTrusted(X509Certificate[] chain, String authType) throws CertificateException {
}

public void checkServerTrusted(X509Certificate[] chain, String authType) throws CertificateException {
}
}};
SSLContext sc = SSLContext.getInstance("SSL");
sc.init(null, trustAllCerts, new SecureRandom());
HttpsURLConnection.setDefaultSSLSocketFactory(sc.getSocketFactory());
HttpsURLConnection.setDefaultHostnameVerifier(new HostnameVerifier() {
@Override
public boolean verify(String arg0, SSLSession arg1) {
if (arg0.equalsIgnoreCase("YOUR_DOMAIN OR YOUR IP"))
return true;
else
return false;
}
});
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/49557070

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档