天天看點

iOS推送通知的實作步驟一.關于推送通知 二.Apple Push Notification的工作機制 三.開發證書和推送證書的配置 四.開發帶有推送功能的IOS應用

推送通知,也被叫做遠端通知,是在iOS 3.0以後被引入的功能。是當程式沒有啟動或不在前台運作時,告訴使用者有新消息的一種途徑,是從外部伺服器發送到應用程式上的。一般說來,當要顯示消息或 下載下傳資料的時候,通知是由遠端伺服器(程式的提供者)發送,然後通過蘋果的推送通知服務(Apple Push Notification Service,簡稱apns)推送到裝置的程式上。

推送的新消息可能是一條資訊、一項即将到期的日程或是一份遠端伺服器上的新資料。在系統上展現的時候,可以顯示警告資訊或在程式icon上顯示數字,同 時,也可以播放警告音。一旦使用者注意到程式有新的資訊、時間或是資料,他們可以運作程式并通路新的内容。也可以選擇忽略通知,這時程式将不會被激活。

iPhone, iPad和iPod touch上同一時刻隻有一個app在前台運作。大多數程式在背景運作的時候,可以對某些使用者感興趣的内容做出回應(定時、或資料等)。推送通知能讓程式在這些事件發生的時候通知使用者。

作為提供者為程式開發和部署推送通知,必須通過iOS Developer Program Portal獲得SSL證書。每個證書限用于一個程式,使用程式的bundle ID作為辨別。證書有兩種用途的:一種是針對sandbox(用于開發和測試),另外一種針對釋出産品。這兩種運作環境擁有為各自指定的IP位址并且需要 不同的證書。還必須為兩種不同的環境擷取各自的provisioning profiles。

APNS提供了兩項基本的服務:消息推送和回報服務。

消息推送:使用流式TCP套接字将推送通知作為二進制資料發送給APNs。消息推送有分别針對開發和測試用的sandbox、釋出産品的兩個接口,每個都 有各自的位址和端口。不管用哪個接口,都需要通過TLS或SSL,使用SSL證書來建立一個安全的信道。提供者編制通知資訊,然後通過這個信道将其發送給 APNs。

<a target="_blank">産品接口:gateway.push.apple.com:2195</a>

回報服務:可以得到針對某個程式的發送失敗記錄。提供者應該使用回報服務周期性檢查哪些裝置一直收不到通知,不需要重複發送通知到這些裝置,降低推送伺服器的負擔。

<a target="_blank">注:sandbox:feedback.push.apple.com:2196</a>

<a target="_blank">産品接口:feedback.sandbox.push.apple.com:2196</a>

下面是一個完整推送流程圖

iOS推送通知的實作步驟一.關于推送通知 二.Apple Push Notification的工作機制 三.開發證書和推送證書的配置 四.開發帶有推送功能的IOS應用

 從上圖,我們可以看到。

  首先是應用程式注冊消息推送。

 IOS跟APNS Server要deviceToken。應用程式接受deviceToken。

 應用程式将deviceToken發送給PUSH服務端程式(Provider)。

 服務端程式向APNS服務發送消息。

 APNS服務将消息發送給iPhone應用程式。

無論是iPhone用戶端跟APNS,還是Provider和APNS都需要通過證書進行連接配接的:

iOS推送通知的實作步驟一.關于推送通知 二.Apple Push Notification的工作機制 三.開發證書和推送證書的配置 四.開發帶有推送功能的IOS應用

圖中,

1. Provider是指某個iPhone軟體的Push伺服器,是我們将要開發的伺服器。

2. APNS 是Apple Push Notification Service(Apple Push伺服器)的縮寫,是蘋果的伺服器。

上圖可以分為三個階段:

第一階段:推送伺服器(provider)把要發送的消息、目的iPhone的辨別打包,發給APNS;

第二階段:APNS在自身的已注冊Push服務的iPhone清單中,查找有相應辨別的iPhone,并把消息發到iPhone;

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

1. 使用開發者帳号登入IOS Provisioning ,選擇或建立一個App Id,這裡以“info.luoyl.iostest”為例

iOS推送通知的實作步驟一.關于推送通知 二.Apple Push Notification的工作機制 三.開發證書和推送證書的配置 四.開發帶有推送功能的IOS應用

2. 建立完後,進入App Id清單,可以看到建立的App Id預設是沒有激活推送功能的,點選Configure連結,進入推送功能激活頁面:

iOS推送通知的實作步驟一.關于推送通知 二.Apple Push Notification的工作機制 三.開發證書和推送證書的配置 四.開發帶有推送功能的IOS應用

3. 在“Enable for Apple Push Notification service”選項上打勾,然後在行點“configure”按鈕:

iOS推送通知的實作步驟一.關于推送通知 二.Apple Push Notification的工作機制 三.開發證書和推送證書的配置 四.開發帶有推送功能的IOS應用

4. 此時會彈出一視窗,點“continue”

iOS推送通知的實作步驟一.關于推送通知 二.Apple Push Notification的工作機制 三.開發證書和推送證書的配置 四.開發帶有推送功能的IOS應用

5. 彈出證書上傳頁面,證書選擇事先做好的“CertificateSigningRequest.certSigningRequest”,然後點“Generate”按鈕;

iOS推送通知的實作步驟一.關于推送通知 二.Apple Push Notification的工作機制 三.開發證書和推送證書的配置 四.開發帶有推送功能的IOS應用

6. 接下來會有“Your APNs SSL Certificate has been generated.”提示,點“continue”:

iOS推送通知的實作步驟一.關于推送通知 二.Apple Push Notification的工作機制 三.開發證書和推送證書的配置 四.開發帶有推送功能的IOS應用

7. 下載下傳剛生成的證書“aps_development.cer”到電腦:

iOS推送通知的實作步驟一.關于推送通知 二.Apple Push Notification的工作機制 三.開發證書和推送證書的配置 四.開發帶有推送功能的IOS應用

8. 至此,appid的Development Push SSL Certificate已經變成“Enabled”狀态了:

iOS推送通知的實作步驟一.關于推送通知 二.Apple Push Notification的工作機制 三.開發證書和推送證書的配置 四.開發帶有推送功能的IOS應用

9. 制作一開發者測試證書,appid指定為“info.luoyl.iostest”, 下載下傳後輕按兩下安裝到電腦上:

iOS推送通知的實作步驟一.關于推送通知 二.Apple Push Notification的工作機制 三.開發證書和推送證書的配置 四.開發帶有推送功能的IOS應用

10. 輕按兩下在步驟7下載下傳的“aps_development.cer”安裝到keychain Access上:

iOS推送通知的實作步驟一.關于推送通知 二.Apple Push Notification的工作機制 三.開發證書和推送證書的配置 四.開發帶有推送功能的IOS應用

11. 選中push Services證書,右鍵導出證書為個人資訊交換(.p12)格式檔案,這裡我命名為“aps_development.p12”,點存儲時會彈出一個密碼設定視窗,可留白不填:

iOS推送通知的實作步驟一.關于推送通知 二.Apple Push Notification的工作機制 三.開發證書和推送證書的配置 四.開發帶有推送功能的IOS應用

12. 在終端執行下面的指令,把剛才導出的個人資訊交換(.p12)格式檔案加密轉換成推送伺服器的推送證書:

openssl pkcs12 -clcerts -nokeys -out cert.pem -in aps_development.p12     

   openssl pkcs12 -nocerts -out key.pem -in aps_development.p12     

   openssl rsa -in key.pem -out key.unencrypted.pem     

   cat cert.pem key.unencrypted.pem &gt; iostest_push_dev.pem  

iOS推送通知的實作步驟一.關于推送通知 二.Apple Push Notification的工作機制 三.開發證書和推送證書的配置 四.開發帶有推送功能的IOS應用

      上面的指令在執行時有4處是需要輸入密碼的,其中1和2直接回車,3必須設定一個key如“push”,在4處輸入3設定的key “push”;

指令執行完後生成的“iostest_push_dev.pem”就是我們推送伺服器要使用的推送證書;

      經過以上步驟的配置,已經完成了開發推送功能所需要的條件了,接下來将會建立一個ios應用來體驗完成推送功能,在ios應用需要實作的接口。

為使應用能支援推送功能,我們的項目配置時要注意:

Bundle Identifier、Code Signing指定的開發證書綁定的AppId要和推送證書綁定的AppId一緻(見下圖);

 如 果項目中的開發證書在AppId激活推送功能前已經建立了,這時必須重新生成一個。支援推送功能的開發證書會比舊證書多出一項名為 “aps- environment”的授權串,如果繼續使用舊證書,在程式啟動嘗試注冊推送功能時會出現“ 未找到應用程式的“aps-environment”的權利字元串 ”的錯誤;

測試需要用真機,模拟器不支援。

iOS推送通知的實作步驟一.關于推送通知 二.Apple Push Notification的工作機制 三.開發證書和推送證書的配置 四.開發帶有推送功能的IOS應用
iOS推送通知的實作步驟一.關于推送通知 二.Apple Push Notification的工作機制 三.開發證書和推送證書的配置 四.開發帶有推送功能的IOS應用

在代碼方面,推送的注冊、監聽和處理都集中在AppDelegate類裡:

1.(BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions

在該方法體裡主要實作兩個功能:

一是完成推送功能的注冊請求,即在程式啟動時彈出是否使用推送功能;

二是實作的程式啟動是通過推送消息視窗觸發的,在這裡可以處理推送内容;

- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions     

{     

    self.window = [[[UIWindow alloc] initWithFrame:[[UIScreen mainScreen] bounds]] autorelease];     

    // Override point for customization after application launch.     

    self.viewController = [[[ViewController alloc] init] autorelease];     

    self.window.rootViewController = self.viewController;     

    [self.window setBackgroundColor:[UIColor colorWithPatternImage:[UIImage imageNamed:@"background.png"]]];     

    [self.window makeKeyAndVisible];     

    /** 注冊推送通知功能, */    

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

    //判斷程式是不是由推送服務完成的     

    if (launchOptions) {     

        NSDictionary* pushNotificationKey = [launchOptions objectForKey:UIApplicationLaunchOptionsRemoteNotificationKey];     

        if (pushNotificationKey) {     

            UIAlertView *alert = [[UIAlertView alloc]initWithTitle:@"推送通知"      

                                                           message:@"這是通過推送視窗啟動的程式,你可以在這裡處理推送内容"    

                                                          delegate:nil      

                                                 cancelButtonTitle:@"知道了"      

                                                 otherButtonTitles:nil, nil];     

            [alert show];     

            [alert release];     

        }     

    }     

    return YES;     

}     

 2. 接收從蘋果伺服器傳回的唯一的裝置token,該token是推送伺服器發送推送消息的依據,是以需要發送回推送伺服器儲存

- (void)application:(UIApplication *)app didRegisterForRemoteNotificationsWithDeviceToken:(NSData *)deviceToken {     

    NSString* token = [NSString stringWithFormat:@"%@",deviceToken];     

    NSLog(@"apns -&gt; 生成的devToken:%@", token);     

    //把deviceToken發送到我們的推送伺服器     

    DeviceSender* sender = [[[DeviceSender alloc]initWithDelegate:self ]autorelease];     

    [sender sendDeviceToPushServer:token ];         

3.接收注冊推送通知功能時出現的錯誤,并做相關處理:

- (void)application:(UIApplication *)app didFailToRegisterForRemoteNotificationsWithError:(NSError *)err {     

    NSLog(@"apns -&gt; 注冊推送功能時發生錯誤, 錯誤資訊:\n %@", err);     

}    

4. 接收到推送消息,解析處理

- (void)application:(UIApplication *)application didReceiveRemoteNotification:(NSDictionary *)userInfo     

    NSLog(@"\napns -&gt; didReceiveRemoteNotification,Receive Data:\n%@", userInfo);     

    //把icon上的标記數字設定為0,     

    application.applicationIconBadgeNumber = 0;     

    if ([[userInfo objectForKey:@"aps"] objectForKey:@"alert"]!=NULL) {     

        UIAlertView* alert = [[UIAlertView alloc] initWithTitle:@"**推送消息**"    

                                                        message:[[userInfo objectForKey:@"aps"] objectForKey:@"alert"]     

                                                       delegate:self     

                                              cancelButtonTitle:@"關閉"    

                                              otherButtonTitles:@"處理推送内容",nil];     

        alert.tag = alert_tag_push;     

        [alert show];     

通過上面的代碼,基本推送功能的開發已經完成了。最後附件上面代碼中所需用到的DeviceSender的類檔案,需要将其頭檔案導入到AppDelegate中。下面是DeviceSender類的.h和.m檔案的下載下傳位址:

<a href="http://http//download.csdn.net/detail/enuola/5100134" target="_blank">http://download.csdn.net/detail/enuola/5100134</a>

本文轉自夏雪冬日部落格園部落格,原文連結:XXXXXX,如需轉載請自行聯系原作者