国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 學院 > 開發設計 > 正文

【iOS】iOS消息推送機制的實現

2019-11-14 19:36:05
字體:
來源:轉載
供稿:網友

iOS消息推送的工作機制可以簡單的用下圖來概括:

 

PRovider是指某個iphone軟件的Push服務器,APNS是Apple Push Notification Service的縮寫,是蘋果的服務器。

 

上圖可以分為三個階段:

第一階段:應用程序把要發送的消息、目的iPhone的標識打包,發給APNS。 

第二階段:APNS在自身的已注冊Push服務的iPhone列表中,查找有相應標識的iPhone,并把消息發送到iPhone。 

第三階段:iPhone把發來的消息傳遞給相應的應用程序,并且按照設定彈出Push通知。

 

從上圖我們可以看到:

1、應用程序注冊消息推送。

2、iOS從APNS Server獲取device token,應用程序接收device token。

3、應用程序將device token發送給PUSH服務端程序。

4、服務端程序向APNS服務發送消息。

5、APNS服務將消息發送給iPhone應用程序。

 

無論是iPhone客戶端和APNS,還是Provider和APNS,都需要通過證書進行連接。

 

下面我介紹一下幾種用到的證書。

 

一、CSR文件

 

1、生成Certificate Signing Request(CSR)

 

2、填寫你的郵箱和常用名稱,并選擇保存到硬盤。

 

點擊繼續:

 

這樣就在本地生成了一個Push.certSigningRequest文件。

 

二、p12文件

 

1、導出密鑰。

 

2、輸入你的密碼。

 

 

這樣就生成了一個Push.p12文件。

 

三、SSL certificate文件

 

1、用你付過費的帳號登錄到iOS Provisioning Portal,并新建一個App ID,這個過程可以參考:iOS應用的真機調試,這樣就會生成下面這條記錄:

 

2、點擊右側的Configure:

 

3、點擊Development Push SSL Certificate一行后的Configure:

 

 

4、點擊Continue:

 

5、選擇前面生成好的Push.certSigningRequest文件,點擊Generate,出現如下所示的頁面:

 

6、點擊Continue:

 

7、點擊Download,并將文件命名為aps_developer_identity.cer。

 

8、點擊Done,你會發現狀態變成了Enabled:

 

注意:有的App ID的Apple Push Notification service列是灰色的,并且不允許使用Configure按鈕,這是因為APNS不支持帶通配符的App ID。

 

到現在為止,我們已經生成了三個文件:

 

1、Push.certSigningRequest

2、Push.p12

3、aps_developer_identity.cer

 

在項目的AppDelegate中的didFinishLaunchingWithOptions方法中加入下面的代碼:

 

Ios代碼   收藏代碼
  1. [[UIapplication sharedApplication] registerForRemoteNotificationTypes:(UIRemoteNotificationTypeAlert | UIRemoteNotificationTypeSound | UIRemoteNotificationTypeBadge)];   

 

通過registerForRemoteNotificationTypes方法,告訴應用程序,能接受push來的通知。

 

在項目的AppDelegate中添加下面的方法來獲取deviceToken:

 

Ios代碼   收藏代碼
  1. - (void)application:(UIApplication *)app didRegisterForRemoteNotificationsWithDeviceToken:(NSData *)deviceToken {     
  2.     NSString *token = [NSString stringWithFormat:@"%@", deviceToken];  
  3.     NSLog(@"My token is:%@", token);  
  4. }  
  5.   
  6. - (void)application:(UIApplication *)app didFailToRegisterForRemoteNotificationsWithError:(NSError *)error {      
  7.     NSString *error_str = [NSString stringWithFormat: @"%@", error];  
  8.     NSLog(@"Failed to get token, error:%@", error_str);  
  9. }  

 

獲取到的deviceToken,我們可以提交給后臺應用程序,發送通知的后臺應用程序除了需要知道deviceToken之外,還需要一個與APNS連接的證書。

 

這個證書可以通過我們前面生成的兩個文件中得到。

 

1、將aps_developer_identity.cer轉換成aps_developer_identity.pem格式

 

Shell代碼   收藏代碼
  1. openssl x509 -in aps_developer_identity.cer -inform DER -out aps_developer_identity.pem -outform PEM  

 

2、將p12格式的私鑰轉換成pem

 

Shell代碼   收藏代碼
  1. openssl pkcs12 -nocerts -out Push_Noenc.pem -in Push.p12  

 

3、創建p12文件

 

Shell代碼   收藏代碼
  1. openssl pkcs12 -export -in aps_developer_identity.pem -inkey Push_Noenc.pem -certfile Push.certSigningRequest -name "aps_developer_identity" -out aps_developer_identity.p12  

 

這樣我們就得到了在.net或java等后臺應用程序中使用的證書文件:aps_developer_identity.p12

 

如果后臺應用是php的話,那么可以按照 iOS消息推送機制中pem文件的生成這篇文章中的方法來生成php后臺應用程序中使用的證書文件:ck.pem


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 河间市| 长寿区| 成都市| 苍山县| 沽源县| 楚雄市| 龙口市| 闸北区| 南丹县| 图木舒克市| 清流县| 剑川县| 秦皇岛市| 沅陵县| 苍梧县| 兴义市| 洛浦县| 万载县| 南阳市| 同江市| 裕民县| 新化县| 阳高县| 宁乡县| 深州市| 田东县| 咸阳市| 青河县| 子洲县| 宝山区| 咸宁市| 保山市| 任丘市| 霍城县| 鄂伦春自治旗| 孟州市| 乌拉特中旗| 安阳市| 曲阳县| 金溪县| 民权县|