iOS实现服务器原生推送

iOS原生实现推送

一、iOS推送机制



Provider是给你手机应用发出推送消息的服务器,而APNS(Apple Push Notification Service)则是苹果消息推送服务器。你本地的服务器当需要给应用推送一条消息的时候,先要将消息发出到苹果推送服务器,然后再由苹果推送服务器将消息发到安装了该应用的手机。

接下来再看一张解释图:


根据上图的逻辑:

1. iOS应用需要去注册APNS消息推送功能;

2.当苹果APNS推送服收到来自你应用的注册消息就会给客户端返回一串device token(很重要);

3.将应用收到的device Token传给本地的Push服务器;

4.当你需要为应用推送消息的时候,你本地的推送服务器会将消息;以及Device Token打包发送到苹果的APNS服;

5.APNS再将消息推送给目的iphone。


二、申请推送证书

证书分为开发推送证书和生产推送证书,当在开发真机测试时使用开发推送证书.p12,在AdHoc(打包测试)及上线时使用生产推送证书.p12

三、后台集成推送环境(集成以开发环境为实例)

 

接下来我们打开终端将他们生成.pem文件:

1.  把aps_development .cer文件生成.pcm文件,cd到push文件夹下

yangliang:~ apple$ openssl x509 -in aps_development.cer-inform der -out PushCert.pem

 

2.  将开发证书p.12生产.pem文件:

yangliang:Jpush apple$ openssl pkcs12 -nocerts -outPushCertKey.pem -in 生产证书.p12

进行该步骤是要验证证书的秘钥(需要验证两次密码ABC123)

Enter Import Password:

MAC verified OK

Enter PEM pass phrase:

Verifying - Enter PEM pass phrase:

yangliang:Jpush apple$

 

上边输入的密码则是你导出证书所设的密码,即ABC123 接着还会让你输入.pem文件的密码,还是使用ABC123好了,防止混淆。

 

这样我们在push文件夹中就又得到了两个文件,。

3.  把PushCert.pem和PushCertKey.pem合并为一个pem文件:

yangliang:Jpush apple$ cat PushCert.pem pushCertKey.pem> ck.pem

在push文件夹中又多了一个ck.pem文件,以上我们把需要使用的文件都准备好了

 

四、测试环境

为了测试证书工作的状况,我们可以使用“telnet gateway.sandbox.push.apple.com2195”来检测一下,如果显示:

yangliang:Jpush apple$ telnetgateway.sandbox.push.apple.com 2195

Trying 17.188.137.58...

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

Escape character is '^]'.

则表示成功。

 

最后使用我们生成的证书和私钥来设置一个安全的链接去链接苹果服务器:

yangliang:Jpush apple$ openssl s_client -connectgateway.sandbox.push.apple.com:2195 -cert PushChatCert.pem -key PushKey.pem

 

需要输入密码(

  • 8
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
iOS中,推送弹窗通常使用系统提供的`UNUserNotificationCenter`来实现。下面是一个简单的代码示例,用于在前台时展示推送弹窗: ```swift import UserNotifications class ViewController: UIViewController, UNUserNotificationCenterDelegate { override func viewDidLoad() { super.viewDidLoad() // 设置通知中心的代理 UNUserNotificationCenter.current().delegate = self // 请求用户授权 let center = UNUserNotificationCenter.current() center.requestAuthorization(options: [.alert, .badge, .sound]) { granted, error in if let error = error { print("Error requesting authorization: \(error.localizedDescription)") } // 用户授权后,可以向通知中心注册推送 if granted { DispatchQueue.main.async { UIApplication.shared.registerForRemoteNotifications() } } } } // 实现通知中心的代理方法,用于展示推送通知 func userNotificationCenter(_ center: UNUserNotificationCenter, willPresent notification: UNNotification, withCompletionHandler completionHandler: @escaping (UNNotificationPresentationOptions) -> Void) { // 在前台时展示推送弹窗 completionHandler([.alert, .badge, .sound]) } } ``` 在代码中,首先需要请求用户授权,然后向通知中心注册推送。在`UNUserNotificationCenterDelegate`协议中,实现`userNotificationCenter(_:willPresent:withCompletionHandler:)`方法,用于在前台时展示推送弹窗。由于这个方法是在后台线程中调用的,因此需要在完成之后调用`completionHandler`来通知系统如何处理推送通知。在这个示例中,我们将推送通知以弹窗的形式展示。 需要注意的是,如果应用在前台时收到推送通知,系统默认不会展示弹窗。因此,我们需要在代码中主动调用`completionHandler`来展示弹窗。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值