15

我在我的应用程序中使用 gorbin/ASNE SDK。我最近收到了一封来自 Google 的电子邮件,主题如下:“Google Play 警告:SSL 错误处理程序漏洞”。在这封电子邮件中,谷歌解释说我的应用程序有一个 [“WebViewClient.onReceivedSslError 处理程序的不安全实现”]

他们建议我[“要正确处理 SSL 证书验证,请更改您的代码以在服务器提供的证书符合您的期望时调用 SslErrorHandler.proceed(),否则调用 SslErrorHandler.cancel()”]

这是我对该方法的实现:

   public void onReceivedSslError(WebView view, SslErrorHandler handler, SslError error) {
                handler.proceed();
            }

请问有什么帮助吗?

4

3 回答 3

26

要正确处理 SSL 证书验证,请更改代码以SslErrorHandler.proceed()在服务器提供的证书满足您的期望时调用,SslErrorHandler.cancel()否则调用。

例如,我添加了一个警告对话框以使用户已确认并且似乎 Google 不再显示警告。

    @Override
    public void onReceivedSslError(WebView view, final SslErrorHandler handler, SslError error) {
    final AlertDialog.Builder builder = new AlertDialog.Builder(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;
        }
        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();
}

在此更改后,它将不会显示警告。参考

于 2016-07-15T05:44:10.933 回答
10

解决方案是删除 onReceivedSslError

于 2016-03-01T11:29:08.237 回答
1

我正在使用后端库旧版本编译“com.backendless:backendless:3.0.11”所以我更新到最新版本编译“com.backendless:backendless:3.0.24”并解决了问题。

于 2017-06-15T06:32:39.060 回答