iOS开发如何实现消息推送机制
Push的原理:
Push 的工作機(jī)制可以簡單的概括為下圖
圖中,Provider是指某個iPhone軟件的Push服務(wù)器,這篇文章我將使用.net作為Provider。
APNS 是Apple Push Notification Service(Apple Push服務(wù)器)的縮寫,是蘋果的服務(wù)器。
上圖可以分為三個階段。
第一階段:.net應(yīng)用程序把要發(fā)送的消息、目的iPhone的標(biāo)識打包,發(fā)給APNS。
第二階段:APNS在自身的已注冊Push服務(wù)的iPhone列表中,查找有相應(yīng)標(biāo)識的iPhone,并把消息發(fā)到iPhone。
第三階段:iPhone把發(fā)來的消息傳遞給相應(yīng)的應(yīng)用程序, 并且按照設(shè)定彈出Push通知。
從上圖我們可以看到。
1、首先是應(yīng)用程序注冊消息推送。
2、 IOS跟APNS Server要deviceToken。應(yīng)用程序接受deviceToken。
3、應(yīng)用程序?qū)eviceToken發(fā)送給PUSH服務(wù)端程序。
4、 服務(wù)端程序向APNS服務(wù)發(fā)送消息。
5、APNS服務(wù)將消息發(fā)送給iPhone應(yīng)用程序。
無論是iPhone客戶端跟APNS,還是Provider和APNS都需要通過證書進(jìn)行連接的。下面我介紹一下幾種用到的證書。
幾種證書:
一、*.certSigningRequest文件
1、生成Certificate Signing Request (CSR):
這樣就在本地生成了一個PushChat.certSigningRequest文件。
二、生成*.p12文件
1、導(dǎo)出密鑰,并輸入你的密碼。
這樣就生成了一個PushChatKey.p12文件。
三、新建一個App ID 和SSL certificate文件
1、用你的付過費的apple帳號登錄到iOS Provisioning Portal。新建一個App ID。
Description:中輸入PushChat
Bundle Seed ID:默認(rèn)選擇Generate New
Bundle Identifier:輸入com.mysoft.PushChat
點擊提交
這樣就會生成下面這條記錄:
點擊配置:
這里我們選擇前面生成好的PushChat.certSigningRequest文件,點擊生成。
生成完畢,我們把它下載下來。命名為aps_developer_identity.cer。
點擊完成,你會發(fā)現(xiàn)狀態(tài)變成Enabled。
到現(xiàn)在為止,我們已經(jīng)生成了3個文件。
1、PushChat.certSigningRequest
2、PushChatKey.p12
3、aps_developer_identity.cer
現(xiàn)在我們創(chuàng)建一個簡單的iPhone應(yīng)用程序。
1、打開Xcode,選擇創(chuàng)建一個View-based Application。命名如下圖:
2、在PushChatAppDelegate中的didFinishLaunchingWithOptions方法中加入下面代碼:
通過registerForRemoteNotificationTypes方法,告訴應(yīng)用程序,能接受push來的通知。
3、在xcode中運行,會彈出下面的提示框:
選擇OK。表示此應(yīng)用程序開啟消息通知服務(wù)。
在 PushChatAppDelegate.m代碼中添加下面方法獲取deviceToken :
- (void)application:(UIApplication*)application didRegisterForRemoteNotificationsWithDeviceToken:(NSData*)deviceToken{NSLog(@My token is: %@, deviceToken);}- (void)application:(UIApplication*)application didFailToRegisterForRemoteNotificationsWithError:(NSError*)error{NSLog(@Failed to get token, error: %@, error);}
獲取到的deviceToken,我們可以通過webservice服務(wù)提交給.net應(yīng)用程序,這里我簡單處理,直接打印出來,拷貝到.net應(yīng)用環(huán)境中使用。
發(fā)送通知的.net應(yīng)用程序出來需要知道deviceToken之外,還需要一個與APNS連接的證書。
這個證書可以通過我們前面生成的兩個文件中得到。
使用OpenSSL
1、將aps_developer_identity.cer轉(zhuǎn)換成 aps_developer_identity.pem格式。
openssl x509 -in aps_developer_identity.cer -inform DER -out aps_developer_identity.pem -outform PEM
2、將p12格式的私鑰轉(zhuǎn)換成pem,需要設(shè)置4次密碼,密碼都設(shè)置為:abc123。
openssl pkcs12 -nocerts -out PushChat_Noenc.pem -in PushChat.p12
3、用certificate和the key 創(chuàng)建PKCS#12格式的文件。
openssl pkcs12 -export -in aps_developer_identity.pem -inkey PushChat_Noenc.pem -certfile PushChat.certSigningRequest -name aps_developer_identity -out aps_developer_identity.p12
這樣我們就得到了在.net應(yīng)用程序中使用的證書文件:aps_developer_identity.p12。
在.net應(yīng)用程序中發(fā)送通知。
有個開源的類庫:apns-sharp。
地址是:http://code.google.com/p/apns-sharp/。
我們下載源代碼,對里面的JdSoft.Apple.Apns.Notifications做相應(yīng)的調(diào)整就能用了。
我們根據(jù)DeviceToken和p12File對JdSoft.Apple.Apns.Notifications.Test做相應(yīng)的調(diào)整,如下圖。
這樣就OK了。
效果:
通知的代碼:
for (int i = 1; i
用手機(jī)拍的ipad上面的顯示:
總結(jié):這篇文章主要是詳細(xì)的講述了ios消息推送機(jī)制的實現(xiàn),如何通過.net應(yīng)用程序發(fā)送消息給ios應(yīng)用程序。
總結(jié)
以上是生活随笔為你收集整理的iOS开发如何实现消息推送机制的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: Storyboard的简单使用
- 下一篇: iOS 推送通知 客户端实现