当我的服务器尝试根据设备令牌和ck.pem(.pem文件,证书和密钥之间的组合)将通知推送到特定设备时,出现此错误。
Caused by: java.io.IOException: toDerInputStream rejects tag type 45
这是我的eclipse控制台中出现的完整错误消息。
initial
starting push notification sending
2014/03/20 14:28:00:252 INFO net.penril.notification.Initializer: ====Start Push Notification Sending====
SLF4J: Failed to load class "org.slf4j.impl.StaticLoggerBinder".
SLF4J: Defaulting to no-operation (NOP) logger implementation
SLF4J: See http://www.slf4j.org/codes.html#StaticLoggerBinder for further details.
2014/03/20 14:28:04:737 INFO net.penril.notification.Initializer: Total of record data(1)
SMS OID: 465
IOS test
reg id =x769571d187c15cec398c5a02f196249456e8b73f763754fa17060658f87f6f6
com.notnoop.exceptions.InvalidSSLConfig: java.io.IOException: toDerInputStream rejects tag type 45
2014/03/20 14:28:05:374 INFO net.penril.notification.Initializer: Failed send notification to APN
2014/03/20 14:28:05:374 INFO net.penril.notification.Initializer: ====Complete Push Notification Sending====
2014/03/20 14:28:05:374 INFO net.penril.notification.Initializer: =====End=====
starting..
at com.notnoop.apns.internal.Utilities.newSSLContext(Utilities.java:101)
at com.notnoop.apns.ApnsServiceBuilder.withCert(ApnsServiceBuilder.java:170)
at com.notnoop.apns.ApnsServiceBuilder.withCert(ApnsServiceBuilder.java:133)
at net.penril.notification.Initializer.notificationWorker(Initializer.java:156)
at net.penril.notification.Initializer.Initial(Initializer.java:46)
at net.penril.notification.PushNotificationCron$Job.run(PushNotificationCron.java:12)
at EDU.oswego.cs.dl.util.concurrent.ClockDaemon$RunLoop.run(Unknown Source)
at java.lang.Thread.run(Thread.java:724)
Caused by: java.io.IOException: toDerInputStream rejects tag type 45
at sun.security.util.DerValue.toDerInputStream(DerValue.java:847)
at sun.security.pkcs12.PKCS12KeyStore.engineLoad(PKCS12KeyStore.java:1221)
at java.security.KeyStore.load(KeyStore.java:1214)
at com.notnoop.apns.internal.Utilities.newSSLContext(Utilities.java:85)
... 7 more
我怀疑此错误导致此错误
System.out.println("reg id =" + record.getRegId());
ApnsService service = APNS.newService().withCert("/Applications/MAMP/htdocs/xxxxx-mobile/ck.pem", "xxxxxx").withSandboxDestination().build();
String payload = APNS.newPayload().alertBody("This for testing").build();
String token = record.getRegId();
service.push(token, payload);
您对此toDerInputStream rejects tag type 45
有什么想法吗?
我已经在这里研究这个问题:
答案 0 :(得分:12)
如前所述here java-apns期待.p12私钥,而不是.pem文件。
在mac上创建.p12文件的说明在第一个链接中,但如果您在linux上使用openssl工具,则可以使用以下命令创建:
openssl pkcs12 -export -inkey mykey.key -in mykey.pem -out mykey.p12
答案 1 :(得分:4)
我刚刚找到答案。当我尝试生成P12密钥时,我需要在密钥链访问中同时选择私钥和证书。