iOS测试真机用推送证书,后端(PHP)需要生成pem文件

2019-01-03  本文已影响18人  茗涙

大体步骤(简略版)

openssl pkcs12 -clcerts -nokeys -out apns-dev-cert.pem -in apns-dev-cert.p12
openssl pkcs12 -nocerts -out apns-dev-key.pem -in apns-dev-key.p12
cat apns-dev-cert.pem apns-dev-key.pem > apns-dev.pem

正确的pem文件大体是这样的(hello world)

Bag Attributes
    friendlyName: hello world
    localKeyID: hello world 
subject=/UID=hello worldxxxxxx
-----BEGIN CERTIFICATE-----
MIIFj xxxxhello worldxxxxxx
-----END CERTIFICATE-----
Bag Attributes
    friendlyName: hello world
    localKeyID: hello world
Key Attributes: <No Attributes>
-----BEGIN PRIVATE KEY-----
MIIExxxxhello world zzxxxx
-----END PRIVATE KEY-----

问题

导出key 的时候
一定要设置密码
一定要设置密码
一定要设置密码

要不然生产的pem文件里面只有
···
Server certificate
-----BEGIN CERTIFICATE-----
xxxx
-----END CERTIFICATE-----
···
而没有 PRIVATE KEY

PS:如果不想设置密码,可以使用

openssl rsa -in apns-dev-key.pem -out apns-dev-key-noenc.pem

最后再来一次合并

cat apns-dev-cert.pem apns-dev-key-noenc.pem > apns-dev.pem

万事大吉

测试推送,后台的哥们或者姐们没时间陪着联调
请参考 Easy APNs Provider

2019年03月18日16:31:59 线上证书创建pem文件同理

上一篇 下一篇

猜你喜欢

热点阅读