迹忆客 专注技术分享

当前位置:主页 > 学无止境 > 编程语言 > Java >

Java 禁用 SSL 验证

作者:迹忆客 最近更新:2023/07/22 浏览次数:

有时,当我们尝试连接到 URL 时,您可能会收到 SSLHandshakeException 或 IOException 错误。 此错误背后的原因是无法建立 SSL 加密连接。

在 Java 中,当我们尝试打开 SSL 连接时,SSL 协议的 JSSE 实现会执行一些验证过程来检查请求的主机是真实的还是假的。 此检查涉及服务器 X.509 证书的验证。

本文将展示如何在创建 HTTP 连接时禁用此证书验证。 此外,我们将编写一个示例代码,并提供有关该主题的解释,以使其易于理解。


Java 禁用 SSL 验证

在讨论解决方案之前,让我们看看下面当我们尝试连接 URL 时出现的错误:

Caused by: javax.net.ssl.SSLHandshakeException: sun.security.validator.ValidatorException: PKIX path building failed: sun.security.provider.certpath.SunCertPathBuilderException: unable to find valid certification path to requested target
    at sun.security.ssl.Alerts.getSSLException(Alerts.java:110)
    at sun.security.ssl.SSLSocketImpl.fatal(SSLSocketImpl.java:149)
    at sun.security.ssl.Handshaker.fatalSE(Handshaker.java:202)

通过关闭 SSL 的主机验证和证书验证可以避免上述异常。 为此,您可以按照以下示例进行操作。

解决方案:关闭主机验证和证书验证

在下面的示例中,我们说明了如何关闭主机验证和证书验证。 请参阅以下代码。

示例代码:

// importing necessary packages
import java.io.Reader;
import java.net.URL;
import java.io.InputStreamReader;
import java.net.URLConnection;

import javax.net.ssl.SSLContext;
import javax.net.ssl.SSLSession;
import javax.net.ssl.TrustManager;
import javax.net.ssl.HostnameVerifier;
import javax.net.ssl.HttpsURLConnection;
import javax.net.ssl.X509TrustManager;

import java.security.SecureRandom;
import java.security.cert.X509Certificate;

// Our main class
public class DisableSSL{
  public static void main(String[] args) throws Exception {
    // Creating a Trust Manager.
    TrustManager[] TrustMgr = new TrustManager[] {
      new X509TrustManager() {
        public X509Certificate[] getAcceptedIssuers() {
          return null;
        }

        // No Checking required
        public void checkClientTrusted(X509Certificate[] certs, String authType) {}
        
        // No Checking required
        public void checkServerTrusted(X509Certificate[] certs, String authType) {}
    }
  };

  // Installing the Trast manager
  SSLContext SSLCont = SSLContext.getInstance("SSL");
  SSLCont.init(null, TrustMgr, new SecureRandom());
  HttpsURLConnection.setDefaultSSLSocketFactory(SSLCont.getSocketFactory());

  // Creating an all-trusting verifier for Host Name
  HostnameVerifier ValidHost = new HostnameVerifier() {
    public boolean verify(String HostName, SSLSession MySession) {
      return true;
    }
  };

  // Installing an all-trusting verifier for the HOST
  HttpsURLConnection.setDefaultHostnameVerifier(ValidHost);
  URL MyURL = new URL("https://www.example.com/"); // The location URL
  URLConnection connect = MyURL.openConnection(); // Openning the URL connection
  Reader MyReader = new InputStreamReader(connect.getInputStream()); // Creating a reader

  while (true) { // Processing the reader data
    int Chars = MyReader.read(); 
      if (Chars==-1) {
        break;
      }
        System.out.print((char)Chars);
  }
 }
}

我们已经通过注释描述了每一行的用途。 但是,如果深入查看代码,您会发现我们没有为 checkClientTrusted 和 checkServerTrusted 定义任何内容。

这样我们就绕过了验证。 因此,执行上述示例代码将在控制台上获得如下所示的输出。

<!doctype html>
<html>
<head>
    <title>Example Domain</title>

    <meta charset="utf-8" />
    <meta http-equiv="Content-type" content="text/html; charset=utf-8" />
    <meta name="viewport" content="width=device-width, initial-scale=1" />
    <style type="text/css">
    body {
        background-color: #f0f0f2;
        margin: 0;
        padding: 0;
        font-family: -apple-system, system-ui, BlinkMacSystemFont, "Segoe UI", "Open Sans", "Helvetica Neue", Helvetica, Arial, sans-serif;

    }
    div {
        width: 600px;
        margin: 5em auto;
        padding: 2em;
        background-color: #fdfdff;
        border-radius: 0.5em;
        box-shadow: 2px 3px 7px 2px rgba(0,0,0,0.02);
    }
    a:link, a:visited {
        color: #38488f;
        text-decoration: none;
    }
    @media (max-width: 700px) {
        div {
            margin: 0 auto;
            width: auto;
        }
    }
    </style>
</head>

<body>
<div>
    <h1>Example Domain</h1>
    <p>This domain is for use in illustrative examples in documents. You may use this
    domain in literature without prior coordination or asking for permission.</p>
    <p><a href="https://www.iana.org/domains/example">More information...</a></p>
</div>
</body>
</html>

转载请发邮件至 1244347461@qq.com 进行申请,经作者同意之后,转载请以链接形式注明出处

本文地址:

相关文章

如何在 Java 中延迟几秒钟的时间

发布时间:2023/12/17 浏览次数:217 分类:Java

本篇文章主要介绍如何在 Java 中制造程序延迟。本教程介绍了如何在 Java 中制造程序延时,并列举了一些示例代码来了解它。

如何在 Java 中把 Hashmap 转换为 JSON 对象

发布时间:2023/12/17 浏览次数:187 分类:Java

它描述了允许我们将哈希图转换为简单的 JSON 对象的方法。本文介绍了在 Java 中把 Hashmap 转换为 JSON 对象的方法。我们将看到关于创建一个 hashmap,然后将其转换为 JSON 对象的详细例子。

如何在 Java 中按值排序 Map

发布时间:2023/12/17 浏览次数:171 分类:Java

本文介绍了如何在 Java 中按值对 Map 进行排序。本教程介绍了如何在 Java 中按值对 Map 进行排序,并列出了一些示例代码来理解它。

如何在 Java 中打印 HashMap

发布时间:2023/12/17 浏览次数:192 分类:Java

本帖介绍了如何在 Java 中打印 HashMap。本教程介绍了如何在 Java 中打印 HashMap 元素,还列举了一些示例代码来理解这个主题。

在 Java 中更新 Hashmap 的值

发布时间:2023/12/17 浏览次数:146 分类:Java

本文介绍了如何在 Java 中更新 HashMap 中的一个值。本文介绍了如何在 Java 中使用 HashMap 类中包含的两个方法-put() 和 replace() 更新 HashMap 中的值。

Java 中的 hashmap 和 map 之间的区别

发布时间:2023/12/17 浏览次数:79 分类:Java

本文介绍了 Java 中的 hashmap 和 map 接口之间的区别。本教程介绍了 Java 中 Map 和 HashMap 之间的主要区别。在 Java 中,Map 是用于以键值对存储数据的接口,

在 Java 中获取用户主目录

发布时间:2023/12/17 浏览次数:218 分类:Java

这篇文章向你展示了如何在 Java 中获取用户主目录。本教程介绍了如何在 Java 中获取用户主目录,并列出了一些示例代码以指导你完成该主题。

Java 中 size 和 length 的区别

发布时间:2023/12/17 浏览次数:179 分类:Java

这篇文章教你如何知道 Java 中大小和长度之间的区别。本教程介绍了 Java 中大小和长度之间的区别。我们还列出了一些示例代码以帮助你理解该主题。

Java 中的互斥锁

发布时间:2023/12/17 浏览次数:111 分类:Java

了解有关 Java 中互斥锁的一切,在计算机科学领域,互斥或互斥被称为并发控制的属性。每台计算机都使用称为线程的最小程序指令序列。有一次,计算机在一个线程上工作。为了更好地理解,

扫一扫阅读全部技术教程

社交账号
  • https://www.github.com/onmpw
  • qq:1244347461

最新推荐

教程更新

热门标签

扫码一下
查看教程更方便