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

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

d7599a115cef

d7599a115cef

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

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

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

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

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

第二步:专用密钥证书

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

d7599a115cef

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

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

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

d7599a115cef并创建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   专用密钥生成的新文件名.pemEnter pass phrase for PushChatKey.pem: 此处输入步骤3中设置的密语,

出现:

d7599a115cef这样的结果即是没有问题的,如果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:"")

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相关文件放在服务器上,进行推送相关测试吧

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值