android gcm服务器中的ssl握手exception

嗨朋友我是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.

我无法解决它。

禁用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; } }; 

您需要将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信息。

希望这有帮助! 玩的开心!