我很难弄清楚如何将消息从我的服务器发送到 APNS。我使用过 Moon-APNS 和 APNS-Sharp,但我遇到了同样的错误,即“参数不正确”。我使用 KeyChain 生成了 p12 文件。我将文件拖到我的 Win 7 虚拟环境中,并将其放在 bin\debug 文件夹中。以下是 Moon-APNS 的代码:
static void Main(string[] args)
{
var deviceToken = "21212d6fefebde4d317cab41afff65631b5a4d47e5d85da305ec610b4013e616";
var payload = new NotificationPayload(deviceToken, "hello world");
var notificationList = new List<NotificationPayload>() { payload };
var push = new PushNotification(true, "ushNotificationTest.p12", "pushchat");
var result = push.SendToApple(notificationList);
Console.WriteLine("Hello World");
}
有人有想法吗?
Best Answer-推荐答案 strong>
我认为这会对你有所帮助:
OSX 钥匙串(keychain)
在 iPhone Developer Program Portal 中创建适当的推送通知证书后,您应该已经下载了一个名为 apn_developer_identity.cer 的文件。如果你还没有这样做,你应该打开/导入这个文件到钥匙串(keychain),进入你的登录部分。
最后,如果您过滤钥匙串(keychain)以显示您的登录容器的证书,您应该会看到您的证书已列出。展开证书,下面/附加到它应该有一个 key 。
右键单击或 Ctrl+单击相应的证书并选择导出。钥匙串(keychain)会要求您选择要导出的密码。选择一个并记住它。您最终应该得到一个 .p12 文件。您将需要此文件和您选择的密码才能在此处使用通知和反馈库。
开放式SSL
这里是如何使用 open ssl 创建一个 PKCS12 格式文件,你需要你的开发者私钥(可以从钥匙串(keychain)中导出)和 CertificateSigningRequest??.certSigningRequest
1. Convert apn_developer_identity.cer (der format) to pem:
openssl x509 -in apn_developer_identity.cer -inform DER -out apn_developer_identity.pem -outform PEM}
2. Next, Convert p12 private key to pem (requires the input of a minimum 4 char password):
openssl pkcs12 -nocerts -out private_dev_key.pem -in private_dev_key.p12
3. (Optional): If you want to remove password from the private key:
openssl rsa -out private_key_noenc.pem -in private_key.pem
4. Take the certificate and the key (with or without password) and create a PKCS#12 format file:
openssl pkcs12 -export -in apn_developer_identity.pem -inkey private_key_noenc.pem -certfile CertificateSigningRequest??.certSigningRequest -name "apn_developer_identity" -out apn_developer_identity.p12
我发现 Moon-APNS 更易于在我的应用中使用和配置。
关于ios - 使用 Moon-APNS 或 APNS-Sharp 的 Apple 推送通知,我们在Stack Overflow上找到一个类似的问题:
https://stackoverflow.com/questions/7080318/
|