Android APP之WebView如何校验SSL证书

Android系统的碎片化很严重,并且手机日期不正确、手机根证书异常、WebView BUG等各种原因,都会导致WebViewClient无法访问HTTPS站点。SSL错误的处理方式十分关键,如果处理不当,可能导致中间人攻击,黑客窃听数据,进而引发安全事故。

严谨地处理onReceivedSslError尤为重要。请参考以下代码,原理是:如果WebView报告SSL错误,程序将会对服务器证书进行强校验,如果服务器传入证书的指纹(sha256)与记录值一致,说明WebView验证过程存在缺陷(如:手机日期错误、根证书被删除 等),忽略SSL错误;如果证书匹配失败,表明数据通信有问题,保留阻断。

请先点击 这里,获取证书的指纹(sha256),然后调整代码中的SHA256数组变量。如果APP需要访问多张证书,请在代码中加入多个证书指纹数值。在测试代码时,请将手机日期设置在证书有效期之前,判断WebView是否能正常访问HTTPS站点。

webview.setWebViewClient(new WebViewClient() {
    @Override
    public void onReceivedSslError(WebView view, SslErrorHandler handler, SslError error) {
        if (error.getPrimaryError() == SslError.SSL_DATE_INVALID  // 日期不正确
            || error.getPrimaryError() == SslError.SSL_EXPIRED // 日期不正确
            || error.getPrimaryError() == SslError.SSL_INVALID // WebView BUG
            || error.getPrimaryError() == SslError.SSL_UNTRUSTED) { // 根证书丢失
            if (chkMySSLCNCert(error.getCertificate())) {
                handler.proceed();  // 如果证书一致,忽略错误
            }
        }
    }

    private boolean chkMySSLCNCert(SslCertificate cert) {
        byte[] SHA256 = { 35, 76, 110, -121, -68, -104, -12, 84, 39, 119, -55,
            101, 95, -8, -90, 9, 36, -108, 5, -57, 76, -98, -19, -73, 91, -37, 18,
            64, 32, -41, 0, 109 };  //证书指纹
        Bundle bundle = SslCertificate.saveState(cert);
        byte[] bytes = bundle.getByteArray("x509-certificate");
        if (bytes != null) {
            try {
                CertificateFactory cf = CertificateFactory.getInstance("X.509");  
                Certificate ca = cf.generateCertificate(new ByteArrayInputSteam(bytes));  
                MessageDigest sha256 = MessageDigest.getInstance("SHA-256");
                byte[] Key = sha256.digest(((X509Certificate) ca).getEncoded());
                return Arrays.equals(key, MySSLCNSHA256);
            } catch (Exception Ex) {}
        }
        return false;
    }
}
上一篇 Android WebView实现HTTPS证书校验
下一篇 您的设备与此版本不兼容 Your device isn't compatible with this version 部分设备无法从Google Play下载应用
目录
文章列表
1 MySQL 导入数据
MySQL 导入数据
2
Maven 插件之 docker-maven-plugin 的使用
Maven 插件之 docker-maven-plugin 的使用
3
Redis 数据备份与恢复
Redis 数据备份与恢复
4
Logstash配置过滤Spring Cloud心跳日志
Logstash配置过滤Spring Cloud心跳日志
5
Spring Boot通过Nacos动态获取yaml配置的List数组对象并映射
Spring Boot通过Nacos动态获取yaml配置的List数组对象并映射
最新评论
一位WordPress评论者
一位WordPress评论者
2月12日
您好,这是一条评论。若需要审核、编辑或删除评论,请访问仪表盘的评论界面。评论者头像来自 Gravatar。