java - 在 Java 中获取 SSLHandshakeException

标签 java eclipse ssl https digital-certificate

我在从简单的 java stub 调用 https restful web 服务时在 eclipse 中遇到 SSL Hand Shake 错误,但是,在将客户端数字证书导入服务提供商共享的浏览器后,可以从浏览器访问此 URL。出于安全目的隐藏端点 URL。 请帮助我,我是从 Java 客户端使用 https Web 服务的新手。

JAVA stub 如下:

 try {
          URL url = new URL("https://*********************");
             conn = (HttpURLConnection) url.openConnection();
            conn.setRequestMethod("GET");
            conn.setRequestProperty("enctype","multipart/form-data");
            conn.setRequestProperty("Accept", "text/xml");
            System.out.println("Printing Connetion Object "+conn);
        if (conn.getResponseCode() != 200) {
            throw new RuntimeException("Failed : HTTP error code : "
                    + conn.getResponseCode());
        }

        BufferedReader br = new BufferedReader(new InputStreamReader(
            (conn.getInputStream()))); 
        String output;
        System.out.println("Output from Server .... \n");
        while ((output = br.readLine()) != null) {
            System.out.println(output);
        }
        conn.disconnect();
      } catch (MalformedURLException e) {
          System.out.println("MalformedURLException-->"+conn);
        e.printStackTrace();
      } catch (IOException e) {
          System.out.println("IOException-->"+conn);
        e.printStackTrace();

      }

报错如下:

javax.net.ssl.SSLHandshakeException: Received fatal alert: handshake_failure
    at com.sun.net.ssl.internal.ssl.Alerts.getSSLException(Alerts.java:174)
    at com.sun.net.ssl.internal.ssl.Alerts.getSSLException(Alerts.java:136)
    at com.sun.net.ssl.internal.ssl.SSLSocketImpl.recvAlert(SSLSocketImpl.java:1720)
    at com.sun.net.ssl.internal.ssl.SSLSocketImpl.readRecord(SSLSocketImpl.java:954)
    at com.sun.net.ssl.internal.ssl.SSLSocketImpl.performInitialHandshake(SSLSocketImpl.java:1138)
    at com.sun.net.ssl.internal.ssl.SSLSocketImpl.startHandshake(SSLSocketImpl.java:1165)
    at com.sun.net.ssl.internal.ssl.SSLSocketImpl.startHandshake(SSLSocketImpl.java:1149)
    at sun.net.www.protocol.https.HttpsClient.afterConnect(HttpsClient.java:434)
    at sun.net.www.protocol.https.AbstractDelegateHttpsURLConnection.connect(AbstractDelegateHttpsURLConnection.java:166)
    at sun.net.www.protocol.http.HttpURLConnection.getInputStream(HttpURLConnection.java:1172)
    at java.net.HttpURLConnection.getResponseCode(HttpURLConnection.java:379)
    at sun.net.www.protocol.https.HttpsURLConnectionImpl.getResponseCode(HttpsURLConnectionImpl.java:318)

最佳答案

如果导入到 keystore 无法解决您的问题.. 因为我无法解决它。 然后添加以下代码行。它对我有用。

System.setProperty( "javax.net.ssl.keyStore", "D:\\G2B.p12" );  // The path to the .p12 file
          System.setProperty( "javax.net.ssl.keyStorePassword", "****" );  // The password of the p12 file
          System.setProperty( "javax.net.ssl.keyStoreType", "pkcs12" );  // Default is JKS, we're using PKCS12

关于java - 在 Java 中获取 SSLHandshakeException,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30931531/

相关文章:

java - 动态 SSL keystore /证书选择

java - 如何从 Firebase 列表中包含的分支获取数据

java - 在多个选项卡中重用 Fragment

java - Web 服务的部署策略

java - 什么是 Struts .struts.mex 文件

android - 为什么 Android studio 会遇到大写包名的问题?

java - 适应屏幕尺寸的Android按钮布局

java - JFace:为特定节点扩展更多级别

已添加 SSL 证书,但显示 "Kubernetes Ingress controller fake certificate"

ssl - 如何在 Window 7 中使用 TLS 配置 RDP