iOS推送之-PHP实现推送后台服务


关于推送的逻辑,先盗用其他博主的俩张图哈,来源(http://blog.csdn.net/newjueqi/article/details/7898591)

iOS推送之-PHP实现推送后台服务_第1张图片


关于iOS的推送,我的理解就是iphone客户端一打开,用户接受推送服务,向APNS服务端注册了设备标识,获取到APNS返回的deviceToken值,这个deviceToken传递给推送后台,推送后台将deviceToken和推送内容传递给APNS服务器,APNS通过这个deviceToken得到这个唯一的设备标识,将推送内容发送到设备上。

当然这只是一个概念性的逻辑实现,其中提供数据传递的基础就是Apple的各种证书了,其中需要的证书包含了PHP后台需要的证书、iPhone客户端推送服务以及测试或者发布版证书什么的。后者是保证客户端可以接收到推送消息的基础

关于PHP后台需要的证书获取:

第一步:创建CSR证书(具体自行百度):

iOS推送之-PHP实现推送后台服务_第2张图片

注意!:这里在钥匙串证书管理中创建的Certificate Signing Request(CSR)文件创建时候的名称需要留意,最好是唯一标识,自己要分得清,接下来要根据这个标识来查找专用密钥证书,同时CSR文件要保存到磁盘上,作为app证书请求文件

第二步:专用密钥证书

在钥匙串的密钥项中找到刚刚创建CSR时候命名的那个专用密钥,右键导出为p12文件,

导出时候会提示输入密码:

iOS推送之-PHP实现推送后台服务_第3张图片

注意!这里的密码要记住,后面要用:

第三步:创建项目、创建App ID,并配置此App ID所属项目打开Push Notification 服务开关,

iOS推送之-PHP实现推送后台服务_第4张图片

并创建APNS推送服务证书,证书下载下来和前面的那个p12文件保存到同一个文件夹中

以及创建development或者distrbute的证书,根据需要创建发布版本或者测试版本的证书,

第四步:(重中之重)

打开命令行程序:

1:进入前面的推送证书和专用密钥证书所在文件目录

cd  【证书所在文件目录】

2:生成【自定义的证书文件标识名.pem】文件

openssl x509 -in  推送证书名.cer -inform der -out  自定义的证书文件标识名.pem

3:生成【自定义的私钥证书文件标识名.pem】文件,

openssl pkcs12 -nocerts -out 自定义的证书文件标识名.pem -in 专用密钥文件名.p12

此时需要输入密码。这个密码就是前面导出专用密钥文件时候输入的密码,之后需要我们对生成的pem文件设置一个密语,这里我们推荐还是用上面这个密码,防止混乱(当然你也可以设置成别的更有意义的密语),这里的密语是要告诉我们服务器的。这样,文件就生成了

4.将3和2生成的文件转换为一个文件:(sum为最终生成的pem文件,文件名可以自己随便定义)

cat 文件名.pem   文件名.pem> sum.pem

5:测试证书是否工作

$  telnet gateway.sandbox.push.apple.com 2195

Trying 17.172.232.226…

Connected to gateway.sandbox.push-apple.com.akadns.NET.

以上表示正常,controll + c结束

6:测试连接:

openssl s_client -connect gateway.sandbox.push.apple.com:2195

-cert  推送证书生成的新文件名.pem -key   专用密钥生成的新文件名.pem

Enter pass phrase for PushChatKey.pem: 此处输入步骤3中设置的密语,

出现:


iOS推送之-PHP实现推送后台服务_第5张图片

这样的结果即是没有问题的,如果return code是 20,且verify error:num=20:unable to get local issuercertificate,也是没有问题的,亲测没有问题

至此证书制作完成,即前面俩个文件合并生成的sum.pem文件,可以提供给PHP后台使用,同时将密语提供给后台。

第五步:

编写iOS客户端推送相关内容,自行百度,注意一点:

在deviceToken注册成功后将deviceToken字段回传给后台,后台保存下来,根据这个字段通过APNS推送到指定的设备

func application(_ application: UIApplication, didRegisterForRemoteNotificationsWithDeviceToken deviceToken: Data) {

let device = NSData(data: deviceToken)

let deviceId = device.description.replacingOccurrences(of:"<", with:"").replacingOccurrences(of:">", with:"").replacingOccurrences(of:" ", with:"")

print("我的deviceToken--hello--\(deviceId)")

let url = "http://*****"

let para = ["str": deviceId]

Alamofire.request(url, method: .get, parameters: para )

.responseJSON { (response) in

print("response:\(response)")

switch (response.result) {

case .failure(let error):

print("deviceToken 提交失败:\(error)")

break

case .success(let val):

print("deviceToken 提交成功:\(val)")

}

}

}

第六步:PHP

将sum.pem文件和php文件放在同以目录文件夹下,

php代码:百度吧,相关pem文件、密语配置好,deviceToken字段尽量写活络(通过步骤五中保存的deviceToken字段确定给哪个设备推送),至此,编码工作结束,php相关文件放在服务器上,进行推送相关测试吧

你可能感兴趣的:(iOS推送之-PHP实现推送后台服务)