本文介绍: 在使用WebView加载https源文件时,如果认证证书不被Android认可,那么可能出现无法成功加载对应资源问题。那么,我们就要针对这一状况作出对应处理。为了解决这个问题,请看以下两个方案(二选一):方案一1、启用mixed content。在Android5.0中,WebView方面做了些修改,如果你的系统target api为21以上:系统默认禁止了mixed content第三方cookie可以使用setMixedContentMode() 和 setAcceptThir

        在使用WebView加载https源文件时,如果认证证书不被Android认可,那么可能出现无法成功加载对应资源问题。那么,我们就要针对这一状况作出对应的处理。为了解决这个问题,        ​​​​​​​        

        请看以下两个方案(二选一):

        方案一(推荐使用)

        1、启用mixed content

        在Android 5.0中,WebView方面做了些修改,如果你的系统target api为21以上:

        在使用WebView的类中添加如下代码

// android 5.0以上默认支持Mixed Content,设置支持Mixed Content
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.LOLLIPOP) {

                webView.getSettings().setMixedContentMode(
    
        WebSettings.MIXED_CONTENT_COMPATIBILITY_MODE);
}


        方案二(不推荐上架谷歌商店会被禁止)

        设置WebView接受所有网站证书,在认证证书不被android所接受的情况下,我们可以通过设置重写WebViewClient的onReceivedSslError方法在其中设置接受所有网站的证书来解决,具体代码如下

webView.setWebViewClient(new WebViewClient() {

            
@Overridepublic void onReceivedSslError(WebView view,
SslErrorHandler handler, SslError error) {
		
//super.onReceivedSslError(view, handler, error);
                
// TODO Auto-generated method stub
                
// handler.cancel();// Android默认处理方式

                
handler.proceed();// 接受所有网站的证书

            
}

});	

        注意:在重写WebViewClient的onReceivedSslError方法时,注意一定要去除onReceivedSslError方法super.onReceivedSslError(view, handler, error);,否则设置无效

如对此有疑问,请联系qq1164688204。

推荐Android开源项目

项目功能介绍:RxJava2和Retrofit2项目添加自动管理token功能,添加RxJava2生命周期管理,使用App架构设计是MVP模式和MVVM模式,同时使用组件化,部分代码使用Kotlin,此项目持续维护中。

项目地址https://gitee.com/urasaki/RxJava2AndRetrofit2

原文地址:https://blog.csdn.net/NakajimaFN/article/details/123953903

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任

如若转载,请注明出处:http://www.7code.cn/show_41184.html

如若内容造成侵权/违法违规/事实不符,请联系代码007邮箱suwngjj01@126.com进行投诉反馈,一经查实,立即删除

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注