Я реализовал onReceivedSslError
метод в моем WebViewClient для правильной обработки недействительного сертификата https в веб-просмотре:
@Override
public void onReceivedSslError(WebView view, final SslErrorHandler handler, SslError error) {
final AlertDialog.Builder builder = new AlertDialog.Builder(WebActivity.this);
String message = "SSL Certificate error.";
switch (error.getPrimaryError()) {
case SslError.SSL_UNTRUSTED:
message = "The certificate authority is not trusted.";
return;
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", (dialog, which) -> handler.proceed());
builder.setNegativeButton("cancel", (dialog, which) -> handler.cancel());
final AlertDialog dialog = builder.create();
dialog.show();
}
Когда веб-просмотр загружает мою веб-страницу, обнаруживается ошибка SslError.SSL_UNTRUSTED
.Однако если я открою один и тот же точный URL-адрес в Chrome (как для настольного компьютера, так и для мобильного), сертификат будет считаться действительным и доверенным:
Почему это происходит?