欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

iOS消息推送原理及具體實現(xiàn)代碼

 更新時間:2016年09月21日 15:37:33   作者:山天大畜  
這篇文章主要為大家詳細介紹了iOS 消息推送原理及具體實現(xiàn)代碼,具有一定的參考價值,感興趣的小伙伴們可以參考一下

一、消息推送原理

在實現(xiàn)消息推送之前先提及幾個于推送相關概念,如下圖1-1:

1、Provider:就是為指定IOS設備應用程序提供Push的服務器,(如果IOS設備的應用程序是客戶端的話,那么Provider可以理解為服務端[消息的發(fā)起者]);

2、APNS:Apple Push Notification Service[蘋果消息推送服務器];

3、iPhone:用來接收APNS下發(fā)下來的消息;

4、Client App:IOS設備上的應用程序,用來接收iphone傳遞APNS下發(fā)的消息到制定的一個客戶端app[消息的最終響應者];

上圖可以分為三個階段:

階段一:Provider[服務端]把要發(fā)送的消息,目的IOS設備標識打包,發(fā)送給APNS;

階段二:APNS在自身的已注冊Push服務的IOS設備列表中,查找有相應標識的IOS設備,并將消息發(fā)送到IOS設備;

階段三:IOS設備把發(fā)送的消息傳遞給對應的應用程序,并且按照設定彈出Push通知。

具體過程,如下圖1-2:

1、[Client App]注冊消息推送;

2、[Client App]跟[APNS Service]要deviceToken, Client App接收deviceToken;

3、[Client App]將deviceToken發(fā)送給[Provider]Push服務端程序;

4、當Push服務端程序滿足發(fā)送消息條件了,[Provider]向[APNS Service]發(fā)送消息;

5、[APNS Service]將消息發(fā)送給[Client App].

二、消息推送實現(xiàn)

1、生成*.certSigningRequest文件,步驟如下:

[MacBook-應用程序-實用工具-鑰匙串訪問-證書助手-從證書機構求證書-證書信息(用戶電子郵箱地址{填寫您的郵箱,如:your@email.com},常用名稱{任意,如:PushDemo},請求是:{單選,選擇‘存儲到磁盤'})-繼續(xù)-保存],這時會在您指定的地方生成你指定的文件,默認為CertificateSigningRequest.certSigningRequest文件,這里命名為:PushDemo.certSigningRequest.在此*.certSigningRequest已經(jīng)生成,具體操作步驟如圖所示。

如果生成成功,則會在[鑰匙串訪問|登錄|密鑰]欄目中列出與*.certSigningRequest關聯(lián)的密鑰,這里是PushDemo,如圖所示:

2、新建一個App ID(在蘋果開發(fā)者賬號中配置)

(1)登錄iOS Dev Center,登錄成功后,點擊(iOS Provisioning Portal對應鏈接),如圖所示:

(2)創(chuàng)建New App ID[App IDsàManageàNew App ID]( Description{填寫您對此App ID的描述,如:iShop},Bundle Seed ID(App ID Prefix){選擇綁定App ID前綴,如:默認選擇Generate New},Bundle Identifier(App ID Suffix){填寫綁定App ID后綴,如:com.yourcorp.iShop}),如下圖所示:

這樣就會生成下面這條記錄,如圖所示:

(3)配置上一步中生成的App ID,讓其支持消息推送[點擊2-6中的Configureà選中Enable for Apple Push Notification serviceà點擊Configure],如圖所示:

(4) Generate a Certificate Signing Request(生成部署請求認證)[點擊2-7中的2ConfigureàContinueà步驟1生成的*certSigningRequest文件(這里是iShop.certSigningRequest)-Generate-生成完成后將其下載下來,命名為:aps_developer.cer],雙擊aps_developer.cer證書{將證書與密鑰關聯(lián),并將證書導入到MacBook中},如下圖所示:

(5)創(chuàng)建Development Provisioning Profiles[開發(fā)許可配置文件](Provisioning| Development|New Profile),具體操作流程如下圖所示:

點擊圖中Submit,生成Development Provisioning Profiles[開發(fā)許可配置文件],這里是:iShopDevprofile.mobileprovision如下圖所示:

下載此開發(fā)許可證書(用于聯(lián)機調(diào)試)。

總結,到現(xiàn)在為止,我們已經(jīng)生成:A:*.certSigningRequest文件(在步驟(4)中使用,用于生成證書B)、B:aps_developer_identity.cer證書(在Provider[Push服務器]服務端應用使用)、C:*..mobileprovision開發(fā)許可配置文件(在Client App客戶端應用聯(lián)機調(diào)試使用)。

3、新建一個項目

1. 創(chuàng)建一個"single view application" project,為省事,你設置的"Company Identifier" + "Production“必須和step 5創(chuàng)建的App ID的"bundle identifier"一致。
2. 在AppDelegate.mfile的"didFinishLaunchingWithOptions" method里,添加下列代碼 (用于為app register push notification feature):

//Letthedeviceknowwewanttoreceivepushnotifications
[[UIApplicationsharedApplication]registerForRemoteNotificationTypes:
(UIRemoteNotificationTypeBadge|UIRemoteNotificationTypeSound|UIRemoteNotificationTypeAlert)];



3.在AppDelegate.mfile里添加下列2個methods (用來handle register remote notification with device token和register error的events)
-(void)application:(UIApplication*)applicationdidRegisterForRemoteNotificationsWithDeviceToken:(NSData*)deviceToken

{
NSLog(@"Mytokenis:%@",deviceToken);
}

-(void)application:(UIApplication*)applicationdidFailToRegisterForRemoteNotificationsWithError:(NSError*)error
{
NSLog(@"Failedtogettoken,error:%@",error);
}

4. 運行該app in real device (simulator doesn't support push notification)。這時你會在device上看到一個popup window (該窗口只會出現(xiàn)一次,重裝app不會再出現(xiàn)),提示你該app會send push notification給你,如果同意則clickOK,不同意則click "Now allow”。如果選擇了OK,那么在"Setting > Notifications“里會有你的app在list里。而且這時你的Xcode output console會顯示你的device token。

5: export "PushDemo" private key to a ".p12" file(該文件會在后面生成apns provider的.p12 or .pem file時用到)
1). right click "PushDemo“ private key and select "Export ..."PushDemo
2). Save the private key as “PushDemoKey.p12” file, click Save button
3). 這時會讓你輸入2次用于加密該.p12 file的密碼,例如用"123321",接著會要求你輸入一次your mac account password

6: 在5中生成的“PushDemoKey.p12” file和step 6生成的"aps_development.cer" file是用于APNS provider side的源文件,APNS Provider side進行push message時要用到的"cert + key" file就是通過這2個file來生成。該Step就是用來生成for APNS provider side (php version)要用到這個"cert + key" pem file.

1)open Terminal, go to Desktop (假設這2個file都在desktop里)
2)執(zhí)行下列命令來生成和apns cer file對應的pem file "PushDemoCert.pem"

opensslx509-inaps_development.cer-informder-outPushDemoCert.pem

3)執(zhí)行下列命令來生成和private key .p12 file對應的pem file "PushDemoKey.pem" (注意:執(zhí)行過程會要求你輸入"PushDemoKey.p12"創(chuàng)建時設置的密碼,以及設置"PushDemoKey.pem”的密碼)

opensslpkcs12-nocerts-outPushDemoKey.pem-inPushDemoKey.p12

4)執(zhí)行下列命令把step 11.2生成的cert pem file和step 11.3生成的key pem file合成為一個pem file"PushDemoCK.pem"

catPushDemoCert.pemPushDemoKey.pem>PushDemoCK.pem

7:在5生成的“PushDemoKey.p12” file和step 6生成的"aps_development.cer" file是用于APNS provider side的源文件,該step是簡單測試這2個file是否有效
1)open Terminal, go to Desktop (假設這2個file都在desktop里)
2) 執(zhí)行下列命令來測試是否能夠connect apple提供的不經(jīng)加密(即不需使用任何證書?。┑腁PNS server

telnetgateway.sandbox.push.apple.com2195

如果你看到下列輸出,則表示你的電腦可以connect APNS. 如果出現(xiàn)error,那么check你的firewall是否允許outgoing connections on port 2195。
Trying17.172.233.65...
Connectedtogateway.sandbox.push-apple.com.akadns.net.
Escapecharacteris'^]'.
Press Ctrl+C to close the connection.

3)執(zhí)行下列命令來測試是否能夠connect apple提供的經(jīng)加密(需使用2) and 3)生成的2個pem file!)的APNS "sandbox“ server for development.

openssls_client-connectgateway.sandbox.push.apple.com:2195-certPushDemoCert.pem-keyPushDemoKey.pem

執(zhí)行過程中會要你輸入PushDemoKey.pem生成時設置的密碼。如果connect server成功,就會等待你輸入字串,你可以輸入任意字串,然后回車,就會disconnectserver。如果連接不成功,則openssl會顯示錯誤信息。
注意:實際上有2個APNS servers: the “sandbox” server (用于testing) the live server(用于production mode)。我們這里測試的是sandbox server。live apns server的操作類似。

8:創(chuàng)建provider server side (php version)
1). DownloadSimplePush PHP codeto your mac machine and then unzip it.
2). 去掉SimplePushfolder里的pk.pem (它沒用),把step 11.4生成的"PushDemoCK.pem" copy toSimplePushfolder
3). 修改simplepush.phpfile下面幾行:

// Put your device token here (without spaces):
//device token來自Step 10的第4點,在output console獲取,注意:要去掉前后的尖括號,和中間的所有空格
$deviceToken= '43fcc3cff12965bc45bf842bf9166fa60e8240c575d0aeb0bf395fb7ff86b465';
// Put your private key's passphrase here:
//該值是 3)生成PushDemoKey.pem時設置的密碼
$passphrase= '123456';
// Put your alert message here:
$message= 'My first push notification!';
//.....stream_context_set_option($ctx, 'ssl', 'local_cert', 'PushDemoCK.pem');

4). 在terminal window里,go to the simplepush folder,然后執(zhí)行下列命令,你的iPhone應該會收到一條push message。

phpsimplepush.php

注意:如果你的app在iphone里是正在運行,而且app是在front end時,當它收到push message時是不會出現(xiàn)在iPhone頂部的notification area的!

參考文章:http://mmz06.blog.163.com/blog/static/121416962011111710934946/

以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。     

相關文章

最新評論