【android studio】Android Webview上的ssl warning的处理方式详解及实例

更新时间:2021-06-30    来源:Google    手机版     字体:

【www.bbyears.com--Google】

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

前言:

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

安全提醒

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

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

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

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

然后添加代码如下:

 

 代码如下

publicvoidonReceivedSslError(WebView view,finalSslErrorHandler handler,

  SslError error) {

      finalAlertDialog.Builder builder =newAlertDialog.Builder(WebViewActivity.this);

      String message ="SSL Certificate error.";

      switch(error.getPrimaryError()) {

        caseSslError.SSL_UNTRUSTED:

          message ="The certificate authority is not trusted.";

          break;

        caseSslError.SSL_EXPIRED:

          message ="The certificate has expired.";

          break;

        caseSslError.SSL_IDMISMATCH:

          message ="The certificate Hostname mismatch.";

          break;

        caseSslError.SSL_NOTYETVALID:

          message ="The certificate is not yet valid.";

          break;

        caseSslError.SSL_DATE_INVALID:

          message ="The date of the certificate is invalid";

          break;

        caseSslError.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",newDialogInterface.OnClickListener() {

        @Override

        publicvoidonClick(DialogInterface dialog,intwhich) {

          handler.proceed();

        }

      });

      builder.setNegativeButton("cancel",newDialogInterface.OnClickListener() {

        @Override

        publicvoidonClick(DialogInterface dialog,intwhich) {

          handler.cancel();

        }

      });

      finalAlertDialog dialog = builder.create();

      dialog.show();

 }

 

本文来源:http://www.bbyears.com/seo/126803.html