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

远程推送

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

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

部分摘抄:

苹果官方推送通知过程示意图

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

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

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

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



以下证书制作主要步骤:

1.App ID 的创建

2.Certificates 的创建和配置

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

App ID 的创建

登录Apple Member Center

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

Identifiers 中选中 App ID 接着右上➕号

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

跟随提示操作


跟随提示操作


勾选上 Push Notifictaions


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

 Register


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

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

 Edit

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

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

先来处理一个

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

选啥文件?不知道咱就先晾着

Certificates 的创建和配置

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

哝,看图操作


文明观图

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


就长这个样儿


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


这个是开发环境的


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

剩一朵菊花


配置生产环境

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

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

选长的选长的选长的
.p12

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

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

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

导出开发证书为例

导出 cer.p12文件


导出展开的这个密钥的key. p12文件


此时桌面

我们需要通过终端命令将这些文件转换为. 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

搞定
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 158,560评论 4 361
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 67,104评论 1 291
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 108,297评论 0 243
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 43,869评论 0 204
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 52,275评论 3 287
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 40,563评论 1 216
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 31,833评论 2 312
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,543评论 0 197
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,245评论 1 241
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,512评论 2 244
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 32,011评论 1 258
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,359评论 2 253
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 33,006评论 3 235
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,062评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,825评论 0 194
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 35,590评论 2 273
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,501评论 2 268

推荐阅读更多精彩内容