iOS消息推送機制的實現 (轉 + 修改)

iOS消息推送的工做機制能夠簡單的用下圖來歸納:java


 

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

 

上圖能夠分爲三個階段:app

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

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

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

 

從上圖咱們能夠看到:調試

一、應用程序註冊消息推送。orm

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

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

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

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

 

不管是iPhone客戶端和APNS,仍是Provider和APNS,都須要經過證書進行鏈接。

 

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

 

1、CSR文件(開發者證書, 建立後纔會使用到導出)

 

一、生成Certificate Signing Request(CSR)


 

二、填寫你的郵箱和經常使用名稱,並選擇保存到硬盤。


 

點擊繼續:


 

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

 

2、p12文件

 

一、導出密鑰。



 

二、輸入你的密碼。

 

 

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

 

3、SSL certificate文件

 

一、用你付過費的賬號登陸到iOS Provisioning Portal,並新建一個App ID,這個過程能夠參考:真機調試過程的建立方法, 或者信鴿推送開發者平臺,這樣就會生成下面這條記錄:


 

二、點擊右側的Configure:


 

三、點擊Development Push SSL Certificate一行後的Configure:

 

 

四、點擊Continue:


 

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


 

六、點擊Continue:


 

七、點擊Download,並將文件命名爲aps_developer_identity.cer。

 

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


 

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

 

到如今爲止,咱們已經生成了三個文件:

 

一、Push.certSigningRequest

二、Push.p12

三、aps_developer_identity.cer

 

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

 

  1. [[UIApplication sharedApplication] registerForRemoteNotificationTypes:(UIRemoteNotificationTypeAlert | UIRemoteNotificationTypeSound | UIRemoteNotificationTypeBadge)];   

 

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

 

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

 

  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鏈接的證書。

 

這個證書能夠經過咱們前面生成的兩個文件中獲得。

 

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

 

  1. openssl x509 -in aps_developer_identity.cer -inform DER -out aps_developer_identity.pem -outform PEM  

 

二、將p12格式的私鑰轉換成pem  (在終端裏找到Push.12文件路徑,通常放在桌面,輸入下面的指令,按照步驟3修改文件名字執行生成pem格式的p12文件,用於上傳至推送)

 

  1. openssl pkcs12 -nocerts -out Push_Noenc.pem -in Push.p12  

 

三、建立p12文件

 

  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

相關文章
相關標籤/搜索