美文网首页swift
iOS推送之-PHP实现推送后台服务

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

作者: Funcy1Day | 来源:发表于2017-06-03 17:17 被阅读489次

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

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

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

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

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

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

第二步:专用密钥证书

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

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

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

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

并创建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中设置的密语,

出现:

这样的结果即是没有问题的,如果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实现推送后台服务

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

  • 【知识总结】(2)远程推送

    推送SDK:极光推送 后台点击推送: iOS 10 以下收到推送点击触发 iOS 10 以上触发: 极光推送中使用...

  • iOS_推送原理

    iOS 消息推送机制原理与实现苹果信息推送服务(Apple Push Notification Service),...

  • iOS 远程推送通知

    iOS 远程推送通知 分分钟搞定IOS远程消息推送 iOS推送通知的实现步骤 推送通知iOS客户端编写实现及推送服...

  • 远程推送工具 推荐 -- Push Notifications

    指路牌 推送工具 iOS APNs 适用场景 以iOS为例,模拟后台服务器连接APNs,向设备远程推送信息。 背景...

  • flutter 远程推送

    iOS 如果要在后台的时候收到远程推送,需要设置background modes 如果要处理后台收到的推送,推送消...

  • [iOS篇] iOS推送用PHP做后台

    推送机制: 1.PHP后台把要发送的消息、目的iPhone的标识打包,发送给APNS(apple推送服务器)2.A...

  • java实现iOS后台推送

    证书和服务器地址的选择 注意:后台选择的证书和推送服务器地址一定要和收消息设备的打包方式匹配上才能推送成功。 需...

  • IOS 推送功能

    目录: 1. IOS系统为什么会有推送? 2. 推送的种类; 3. 推送的实现; 4. 第三方推送服务。 1.IO...

  • 实现 iOS 前台时的推送弹窗效果

    实现 iOS 前台时的推送弹窗效果 实现 iOS 前台时的推送弹窗效果

网友评论

    本文标题:iOS推送之-PHP实现推送后台服务

    本文链接:https://www.haomeiwen.com/subject/zwcmfxtx.html