Android APP之WebView如何校验SSL证书
2017-02-17 14:33
453 查看
Android APP之WebView如何校验SSL证书
android开发从入门到精通 标签:Android APP WebView SSL 发布于:2016年12月18日Android系统的碎片化很严重,并且手机日期不正确、手机根证书异常、com.google.android.webview BUG等各种原因,都会导致WebViewClient无法访问HTTPS站点。SSL错误的处理方式十分关键,如果处理不当,可能导致中间人攻击,黑客窃听数据,进而引发安全事故。
严谨地处理onReceivedSslError尤为重要。请参考以下代码,原理是:如果webview报告SSL错误,程序将会对服务器证书进行强校验,如果服务器传入证书的指纹(sha256)与记录值一致,说明webview验证过程存在缺陷(如:手机日期错误、根证书被删除 等),忽略SSL错误;如果证书匹配失败,表明数据通信有问题,保留阻断。
请先点击 ,获取证书的指纹(sha256),然后调整代码中的MySSLCNSHA256数组变量。如果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[] MySSLCNSHA256 = { 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 APP之WebView如何校验SSL证书
- Android APP之WebView校验SSL证书的方法
- android:如何通过chrome远程调试APP中的webView的h5代码
- Android如何区分app原生和webview实现
- Android如何区分app原生和webview实现
- Android如何区分app原生和webview实现
- Android的Webview中,javascript如何调用java方法
- [Android实例] 关于webview如何自动登录保存登录信息
- Android中如何判别WebView加载完毕并使用ProgressDialog进行提示
- android中如何获得webView中的内容
- 如何解决Android WebView出现的乱码问题
- 在android里如何利用WebView实现和javascript通信
- [android开发]WebView如何获得正在打开页面的进度?
- 如何在WebView中建立Android Apps
- Android 编程下 WebView 加载一个网页如何得到网页的 Cookie 值
- Android : 如何在WebView显示的页面中查找内容
- Android App 中把WebView分割固定的 最佳解决方案
- 如何在Android WebView 调用 Javascript 并返回值
- Android webview访问HTTPS web page如何忽略验证
- Android webView是如何使用的