android gcm 服务器中的 ssl 握手异常

ssl handshake exception in android gcm server

嗨,朋友们,我是 android 的新手。我正在尝试创建 gcm 服务器。我的代码是

System.setProperty("javax.net.ssl.trustStore","/usr/bin/keystore.jks");
String id = "cliend id";
String msg = "Test";
Sender sender = new Sender(Api key);
Message message = new Message.Builder()
        .addData("message", "this is the message")
        .addData("other-parameter", "some value")
        .build();
Result result;
result = sender.sendNoRetry(message, id);

我创建了密钥库,但仍然出现如下错误: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.

我无法解决。

您需要将 App2 的证书添加到位于 %JAVA_HOME%\lib\security\cacerts.

的所用 JVM 的密钥库文件中

首先,您可以通过 运行 执行以下命令检查您的证书是否已在密钥库中:keytool -list -keystore "%JAVA_HOME%/jre/lib/security/cacerts"(您没有不需要提供密码)

如果您的证书丢失,您可以通过使用浏览器下载并使用以下命令将其添加到密钥库来获取它:

keytool -import -noprompt -trustcacerts -alias -file -keystore -storepass

导入后您可以运行再次执行第一个命令来检查您的证书是否已添加。

Sun/Oracle资料可以查到here.

希望对您有所帮助!玩得开心!

禁用 SSL。 将此添加到您的代码中。

            TrustManager[] trustAllCerts = new TrustManager[]{new X509TrustManager() {
            public java.security.cert.X509Certificate[] getAcceptedIssuers() {
                return null;
            }

            public void checkClientTrusted(X509Certificate[] certs, String authType) {
            }

            public void checkServerTrusted(X509Certificate[] certs, String authType) {
            }
        }
        };

        // Install the all-trusting trust manager
        SSLContext sc = SSLContext.getInstance("SSL");
        sc.init(null, trustAllCerts, new java.security.SecureRandom());
        HttpsURLConnection.setDefaultSSLSocketFactory(sc.getSocketFactory());

        // Create all-trusting host name verifier
        HostnameVerifier allHostsValid = new HostnameVerifier() {
            public boolean verify(String hostname, SSLSession session) {
                return true;
            }
        };