推送通知 - 引起:java.io.IOException:toDerInputStream 拒绝标签类型 45 [英] Push notification - Caused by: java.io.IOException: toDerInputStream rejects tag type 45

查看:47
本文介绍了推送通知 - 引起:java.io.IOException:toDerInputStream 拒绝标签类型 45的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

当我的服务器尝试根据设备令牌和 ck.pem(.pem 文件、证书和密钥之间的组合)将通知推送到特定设备时,我收到此错误.

I got this error when my server try to push a notification to a specific device based on device token and ck.pem (combination between .pem file, cert and key).

Caused by: java.io.IOException: toDerInputStream rejects tag type 45

这是我的 Eclipse 控制台中出现的完整错误消息.

This is full error message appear in my eclipse console.

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

我怀疑此代码导致此错误

I suspect this error cause by this code

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 拒绝标签类型 45 有什么想法吗?

Do you have any idea about this toDerInputStream rejects tag type 45 ?

我已经在这里研究了这个问题:

I already doing my research about this problem here:

  1. https://community.oracle.com/thread/1534340?开始=0&tstart=0
  2. Java APNS(Apple 推送通知服务)错误

为什么?

推荐答案

我刚刚找到了答案.当我尝试生成 P12 密钥时,我需要在钥匙串访问中同时选择私钥和证书.

I just found the answer. When I try to generate a P12 key, I need to select both, a private key and certificate in keychain access.

这篇关于推送通知 - 引起:java.io.IOException:toDerInputStream 拒绝标签类型 45的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆