iOS 远程推送证书详细制作流程

远程推送

远程推送服务APNs (Apple Push Notification Services)

通俗讲就是从远程服务器推送消息给客户端的通知,当然这需要联网,只要你的苹果设备联网状态,你的设备就与苹果的APNS服务器保持一个长连接状态。友盟、极光、信鸽等远程推送都是必须通过苹果的APNs服务器来实现的。推送原理看这边 ☛ 通知和消息机制

部分摘抄:

iOS 远程推送证书详细制作流程_第1张图片
苹果官方推送通知过程示意图

推送通知的过程可以分为以下几步:

a.应用服务提供商从服务器端把要发送的消息和设备令牌(device token)发送给苹果的消息推送服务器APNs。

b.APNs根据设备令牌在已注册的设备(iPhone、iPad、iTouch、mac等)查找对应的设备,将消息发送给相应的设备。

c.客户端设备接将接收到的消息传递给相应的应用程序,应用程序根据用户设置弹出通知消息。



以下证书制作主要步骤:

1.App ID 的创建

2.Certificates 的创建和配置

3.钥匙串中证书导出.p12格式文件

App ID 的创建

登录Apple Member Center

iOS 远程推送证书详细制作流程_第2张图片

Certificates,Identifiers&Profiles 进入管理页面(已有 App IDs 的找到自己的直接展开编辑,否则按步骤操作)

iOS 远程推送证书详细制作流程_第3张图片
Identifiers 中选中 App ID 接着右上➕号

接着来到了这里, 这下边连着3张图在同个界面

iOS 远程推送证书详细制作流程_第4张图片
跟随提示操作


iOS 远程推送证书详细制作流程_第5张图片
跟随提示操作


iOS 远程推送证书详细制作流程_第6张图片
勾选上 Push Notifictaions


Continue到这里,可以看到之前我勾选了 Push Notification,这里下边有个小菊花警告,有警告就对了,继续往下

iOS 远程推送证书详细制作流程_第7张图片
 Register


一波点击后跳转到了这里,在这里我们 App  IDS中找我们先前创建的 App ID(HeyGirl),点击展开

iOS 远程推送证书详细制作流程_第8张图片

来到这个页面,现在有两盏菊花灯,Edit 进去

iOS 远程推送证书详细制作流程_第9张图片
 Edit

往下拖可以看到,这里讲一下什么是开发环境和生产环境:

你用Xcode编译安装的就是开发环境,用二维码或者App Store下载的就是生产环境.

iOS 远程推送证书详细制作流程_第10张图片
先来处理一个

点击第一个 Create Certificate 后来到这里,它提示我们要上传东西

iOS 远程推送证书详细制作流程_第11张图片
选啥文件?不知道咱就先晾着

Certificates 的创建和配置

来到钥匙串->钥匙串访问->

iOS 远程推送证书详细制作流程_第12张图片
哝,看图操作


iOS 远程推送证书详细制作流程_第13张图片
文明观图

到这里,点继续就可以创建和配置好Certificates了,选个路径放好,我随便丢在了桌面


iOS 远程推送证书详细制作流程_第14张图片
就长这个样儿


还记得晾着的页面吗?回到Apple Member Center,点 Choose File,把刚才从钥匙中生成存在本地的CertificateSigningRequest文件上传上去(文件就长上边那个样),然后 Download 下来.


iOS 远程推送证书详细制作流程_第15张图片
这个是开发环境的


然后咱们还是回到App IDs 这里再找到我的 HeyGirl点进来你会发现,刚刚的两朵小菊花一朵变绿了,就是说咱还有一个生产环境的没配置完, Edit重复上述步骤:选取文件, Download.

iOS 远程推送证书详细制作流程_第16张图片
剩一朵菊花


iOS 远程推送证书详细制作流程_第17张图片
配置生产环境

不出意外你会在下载的文件夹发现多了这两个文件:aps_development.cer和aps.cer,这两个就是下载创建好的Production SSL Certificate,Development SSL Certificate证书,把它们双击添加到钥匙串.

钥匙串中证书导出为P12文件

iOS 远程推送证书详细制作流程_第18张图片
选长的选长的选长的
iOS 远程推送证书详细制作流程_第19张图片
.p12

大功告成,接着用哪个第三方推送服务平台就把.p12往哪搬。

---------我是分割线------------

拓展:以下针对. p12类型转. pem 的操作

导出开发证书为例

iOS 远程推送证书详细制作流程_第20张图片
导出 cer.p12文件


iOS 远程推送证书详细制作流程_第21张图片
导出展开的这个密钥的key. p12文件


iOS 远程推送证书详细制作流程_第22张图片
此时桌面

我们需要通过终端命令将这些文件转换为. pem 类型.

因为我把两个文件都放在桌面

1、$ cd desktop  回车(坑点:不写转换后在桌面找不到多出来的 cer.pem 和 key.pem 文件) 

2、使用openssl 将cer.p12及key.p12转成cer.pem和key.pem

命令如下:

$ openssl pkcs12 -clcerts -nokeys -out cer.pem -in cer.p12

$ openssl pkcs12 -nocerts -out key.pem -in key.p12

注:如果最终的pem在服务端系统使用时不需要密码,则可以执行命令擦除密码:

$ openssl rsa -in key.pem -out key_nopwd.pem

最后会在桌面生成两个pem文件,如:“cer.pem”、“key.pem或者key_nopwd.pem(执行擦除密码命令生成后者)”,那么在3、4步骤也要注意统一为 key_nopwd.pem 执行操作

3、测试生成的cer.pem及key.pem是否可用

$ openssl s_client -connect gateway.push.apple.com:2195  -cert cer.pem -key key.pem

注:gateway.push.apple.com:2195用于appStore app;

gateway.sandbox.push.apple.com:2195用于沙盒app;

以上命令执行后会打印一大罗信息,最后处于可输入状态,打几个字符回车后自动断开连接即为正常。

4、我们需要将键和许可文件合成一个.pem文件,如 ck.pem,此文件在连接到APNS时需要使用,执行命令

$ cat cer.pem key.pem > ck.pem

iOS 远程推送证书详细制作流程_第23张图片
搞定

你可能感兴趣的:(iOS 远程推送证书详细制作流程)