引言:
推播通知是移動終端保持永遠線上概念的一個核心方式,當人們離開案頭互連網以後想在第一時間收到與之相關的資訊時.推播通知的出現就再好不過了.
但是,要注意不可濫用,繁多的非必要性推送訊息會給使用者造成非常煩躁的心理.作為使用者體驗的一部分,那就已經在往失敗的方向走了.
推播通知共為兩種類型,分別是本地推播通知和遠程推播通知. 本文將對這兩類通知的使用展開詳細討論.
參考資料:
1: ios本地通知和遠程通知
http://wangjun.easymorse.com/?p=1482
2: 蘋果遠程通知服務申請啟用例圖 (外國佬寫的.)
http://mobiforge.com/developing/story/programming-apple-push-notification-services
3:書籍參考:iPhone 開發秘籍 第16章 推播通知.
使用:
首先是申請認證的網址
https://developer.apple.com/ios/manage/overview/index.action
登入成功以後,進入iOS 組態管理的 首頁面.
第一步操作是去 建立一個新的App IDs建立成功後,會需要提供安全性憑證來激動推送服務,如:
選擇儲存到磁碟以後,產生一個檔案名稱為(簡稱CSR): CertificateSigningRequest.certSigningRequest
回到Apple頁面 將這個提交並提示激動成功.
啟用成功後的App IDs 提供下載 開發版或是發布版的主動推送認證(aps_development.cer),如果需要做伺服器方面的主動推送的話,就必須要下載這個檔案來使用推送服務了.
第二步要為App提供接受推送許可的認證,點擊Provisioning進行設定,添加一個新的許可,選擇剛剛新建立的App IDs. 再選擇可以調試的iPhone 裝置.
最後,同樣是下載下來: YsyPushMessageDemo.mobileprovision雙擊該認證,讓其載入一次.
接下來,進入iOS工程,選擇使用該認證來調試.
紅圈中,全部設定剛剛載入的許可認證.
那麼到這裡,關於認證類的 準備工作,已經全部準備就緒.
在這裡再此強調一次,每個檔案的具體作用
1: CertificateSigningRequest.certSigningRequest : 為產生App IDs 而用
2: aps_development.cer 為開發主動推送服務而用到的認證
3: YsyPushMessageDemo.mobileprovision 為App 接受推播通知的許可服務
主動推送的Push 代碼 及使用,請參考一開始介紹的第一篇部落格
這裡只附上: https://github.com/stefanhafeneger/PushMeBaby
接下來,說說收到推播通知代碼方面.
1:申請本App需要接受來自服務商提供推送訊息,
[[UIApplication sharedApplication] registerForRemoteNotificationTypes:(UIRemoteNotificationTypeBadge | UIRemoteNotificationTypeSound | UIRemoteNotificationTypeAlert)];
2:申請發出後,如果成功,委託會自動返回一個裝置令牌(toKen),如果失敗,將會進入另外一個失敗的委託
//遠程通知註冊成功委託- (void)application:(UIApplication *)application didRegisterForRemoteNotificationsWithDeviceToken:(NSData *)deviceToken{ NSLog(@"%@",deviceToken); self.viewController.toKenValueTextView.text = [NSString stringWithFormat:@"%@",deviceToken]; self.viewController.pushStatusLabel.text = @"已經註冊.";}//遠程通知註冊失敗委託-(void)application:(UIApplication *)application didFailToRegisterForRemoteNotificationsWithError:(NSError *)error{ self.viewController.toKenValueTextView.text = [error description];}
3:將裝置令牌碼提供給服務商,以供推送到具體的手機上面. 如果遠程推送訊息來了,使用者點擊了推送訊息,或者應用已經處於開啟狀態,系統都會自動調用以下委託:
//點擊某條遠程通知時調用的委託 如果介面處於開啟狀態,那麼此委託會直接響應-(void)application:(UIApplication *)application didReceiveRemoteNotification:(NSDictionary *)userInfo{ NSLog(@"遠程通知"); [self PMD_uesPushMessage:userInfo];}
4: 第三點裡面的介紹的情況是應用程式已經處於運行狀態,上面的委託才會被執行,如果應用程式處於未啟用狀態,此時又需要響應訊息,那麼需要以下委託處理.
- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions{ //這裡處理應用程式如果沒有啟動,但是是通過通知訊息開啟的,此時可以擷取到訊息. if (launchOptions != nil) { NSDictionary *userInfo = [launchOptions objectForKey:UIApplicationLaunchOptionsRemoteNotificationKey]; [self PMD_uesPushMessage:userInfo]; } return YES;}
5:清空通知中樞已有的推送訊息,只需要將指定App 的 Badge 設定為 0即可
[[UIApplication sharedApplication ] setApplicationIconBadgeNumber:0];
6:主動推送的字串必須符合如下Json數組的格式,才能正確推送到手機當中.
@"{
//自訂參數
\"userinfo\":
{
\"name\":\"remote notice\"
},
//標準寫法
\"aps\":
{
\"alert\":
{
\"action-loc-key\":\"Open\",//支援多語言
\"body\":\"messgae content\"//訊息本文
},
\"badge\":1,//為App 的icon 標記 具體數值
\"sound\":\"default\"
//播放的音頻檔案,default 表示系統預設的選擇列鈴聲
}
}";