4

我正在使用 Java APNS(com.notnoop.apns,v0.2.3)将推送通知发送到我的 iOS 应用程序。我正在使用以下几行创建 APNS 服务:

private ApnsService createApnsService() throws IOException {
        ApnsServiceBuilder serviceBuilder = APNS.newService().withCert(certResource.getInputStream(), certPassword);
        serviceBuilder.withSandboxDestination();
        return serviceBuilder.build();
}

并收到以下异常:

org.springframework.web.util.NestedServletException: Request processing failed; nested exception is com.notnoop.exceptions.NetworkIOException: javax.net.ssl.SSLHandshakeException: Received fatal alert: handshake_failure\n\tat org.springframework.web.servlet.FrameworkServlet.processRequest(FrameworkServlet.java:948)\n\tat org.springframework.web.servlet.FrameworkServlet.doPost(FrameworkServlet.java:838)\n\tat javax.servlet.http.HttpServlet.service(HttpServlet.java:647)\n\tat org.springframework.web.servlet.FrameworkServlet.service(FrameworkServlet.java:812)\n\tat javax.servlet.http.HttpServlet.service(HttpServlet.java:728)\n\tat org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:305)...    <<...the stacktrace is much longer, but I've cut it of here, since nobody would read it anyway...>>

我猜我的 P12 证书不正确。(我也尝试过 PEM 证书。)目前我以这种方式创建了 P12 证书,然后应用了密码:

Keychain.app 截图


创建与 Java APNS 兼容的证书的正确方法是什么?

4

2 回答 2

17

我使用 PKCS#12(一个 .p12 文件)。要创建它,我会:

  1. 从 Keychain 导出私钥并命名aps_private-key.p12

  2. 使用以下命令转换密钥 openssl pkcs12 -nocerts -out aps_private-key.pem -in aps_private-key.p12,确保输入至少 4 个字符的 PEM 密码短语。

  3. 从https://developer.apple.com/account/ios/identifiers/bundle/bundleList.action下载应用程序的证书。下载的文件应称为aps_development.cer.

  4. 使用以下命令转换证书openssl x509 -in aps_development.cer -inform der -out aps_development.pem

  5. 使用 生成凭据openssl pkcs12 -export -in aps_development.pem -out aps_dev_credentials.p12 -inkey aps_private-key.pem

  6. 我已准备好使用第 5 步 ( aps_dev_credentials.p12) 中生成的凭据。

    final InputStream certificate = Thread.currentThread().getContextClassLoader()
            .getResourceAsStream("aps_dev_credentials.p12");
    final char[] passwd = {'1','2','3','4'};
    final ApnsService apnsService = com.notnoop.apns.APNS.newService()
            .withCert(certificate, new String(passwd))
            .withSandboxDestination().build();
    apnsService.testConnection();
    
于 2014-12-11T09:18:04.790 回答
3

我在今年早些时候根据本教程创建了它,并且效果很好。

首先遵循这个:http ://raywenderlich.com/32960

然后按照http://code.google.com/p/apns-sharp/wiki/HowToCreatePKCS12Certificate此处的说明获取创建的 .pem 然后进行转换

于 2013-11-20T09:41:26.400 回答