栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 移动开发 > Android

Android Webview上的ssl warning的处理方式详解及实例

Android 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

Android Webview上的ssl warning的处理方式详解及实例

Android Webview上的ssl warning的处理方式详解

前言:

因为最近遇到google pay上汇报的安全漏洞问题,需要处理ssl warning.

安全提醒

您的应用中 WebViewClient.onReceivedSslError 处理程序的实施方式很不安全。具体来说,这种实施方式会忽略所有 SSL 证书验证错误,从而使您的应用容易受到中间人攻击。攻击者可能会更改受影响的 WebView 内容、读取传输的数据(例如登录凭据),以及执行应用中使用 Javascript 的代码。

为了正确处理 SSL 证书验证,请将您的代码更改为在服务器提供的证书符合您的预期时调用 SslErrorHandler.proceed(),否则应调用SslErrorHandler.cancel()。系统已向您的开发者帐号地址发送了一封电子邮件提醒,其中列出了受影响的应用和类。

所以查阅了相关Webview上的访问ssl协议的网址的警告处理方式。

其实大概意思就是说客户端在处理https链接返回的ssl错误的时候不要无脑的直接通过,需要友好的在客户端主动弹出对话框让用户做出选择。

然后添加代码如下:

public void onReceivedSslError(WebView view,final SslErrorHandler handler,
  SslError error) {
      final alertDialog.Builder builder = new alertDialog.Builder(WebViewActivity.this);
      String message = "SSL Certificate error.";
      switch (error.getPrimaryError()) {
 case SslError.SSL_UNTRUSTED:
   message = "The certificate authority is not trusted.";
   break;
 case SslError.SSL_EXPIRED:
   message = "The certificate has expired.";
   break;
 case SslError.SSL_IDMISMATCH:
   message = "The certificate Hostname mismatch.";
   break;
 case SslError.SSL_NOTYETVALID:
   message = "The certificate is not yet valid.";
   break;
 case SslError.SSL_DATE_INVALID:
   message = "The date of the certificate is invalid";
   break;
 case SslError.SSL_INVALID:
 default:
   message = "A generic error occurred";
   break;
      }
      message += " Do you want to continue anyway?";

      builder.setTitle("SSL Certificate Error");
      builder.setMessage(message);

      builder.setPositiveButton("continue", new DialogInterface.onClickListener() {
 @Override
 public void onClick(DialogInterface dialog, int which) {
   handler.proceed();
 }
      });
      builder.setNegativeButton("cancel", new DialogInterface.onClickListener() {
 @Override
 public void onClick(DialogInterface dialog, int which) {
   handler.cancel();
 }
      });
      final alertDialog dialog = builder.create();
      dialog.show();
 }

感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/159660.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号