【iOS】處理推送消息

很多應用都會實現推送功能,我們可以集成第三方框架實現推送功能,比如:
JPush推送:https://www.jpush.cn
個推:http://www.getui.com
下面來說說收到推送消息的邏輯處理

一、收到推送消息有三種情況:
1、應用未啟動(默認顯示在通知欄,或者鎖屏時顯示在鎖屏頁面)
2、應用在后臺掛起(默認顯示在通知欄,或者鎖屏時顯示在鎖屏頁面)
3、應用在前臺(默認不顯示)

二、點擊推送消息有兩種情況:
1、應用未啟動 -> 啟動
這個時候如論是點擊推送消息打開應用還是點擊icon打開應用都會調用以下方法:

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

}

通過launchOptions判斷應用是點擊推送消息打開應用還是點擊icon打開應用,點擊推送消息啟動應用會把推送的消息userInfo通過launchOptions參數傳遞過來。
推送是遠程推送:

if (launchOptions) {
        NSDictionary *userInfo = [launchOptions       objectForKey:UIApplicationLaunchOptionsRemoteNotificationKey];
        if (userInfo) {
                //接收到遠程推送進行相應的邏輯處理
        }
}

推送是本地推送:

if (launchOptions) {
        UILocalNotification *notifi = [launchOptions objectForKey:UIApplicationLaunchOptionsLocalNotificationKey];
        if (notifi) {
                //處理本地推送消息
        }
}

2、應用在后臺 -> 應用在前臺
應用在后臺掛起時點擊推送消息和應用在前臺時收到推送消息,都會調用以下方法:

- (void)application:(UIApplication *)application didReceiveRemoteNotification:(NSDictionary *)userInfo fetchCompletionHandler:(void (^)(UIBackgroundFetchResult result))completionHandler{

}

應用在后臺掛起時默認是不調用該方法的,如果你需要接收到推送消息還沒點擊推送就調用該方法,可以讓服務器發給APNS時在aps 字典中加入:
aps = {
content-available = 1;
}

應用有三種狀態:未啟動、后臺掛起、前臺;我們可以通過以下方法獲取狀態:

NSInteger state = [UIApplication sharedApplication].applicationState;
if (state == UIApplicationStateActive) {
        //應用在前臺
}
else if(state == UIApplicationStateBackground){
        //應用在后臺
}
else if(state == UIApplicationStateInactive){
        //應用從后臺->前臺
}

PS:
最近負責公司項目的推送功能,要求根據推送消息中的“類型”參數判斷具體跳轉位置,項目中使用的是“個推”,下面來簡單說說個推。

個推中有個透傳消息模版,只要應用在前臺就會收到所有發過來的透傳消息(不做任何顯示,顯示需要自己定義),即使關閉推送功能也會收到透傳消息;接受到該消息會調用以下方法:

- (void)GeTuiSdkDidReceivePayload:(NSString *)payloadId andTaskId:(NSString *)taskId andMessageId:(NSString *)aMsgId andOffLine:(BOOL)offLine fromApplication:(NSString *)appId {
        //  收到個推消息
        NSData *payload = [GeTuiSdk retrivePayloadById:payloadId];
        /**
        *匯報個推自定義事件
        *actionId:用戶自定義的actionid,int類型,取值90001-90999。
        *taskId:下發任務的任務ID。
        *msgId: 下發任務的消息ID。
        *返回值:BOOL,YES表示該命令已經提交,NO表示該命令未提交成功。    注:該結果不代表服務器收到該條命令
        **/
        [GeTuiSdk sendFeedbackMessage:90001 taskId:taskId msgId:aMsgId];
}

關于本地推送參考文檔:
http://blog.csdn.net/woaifen3344/article/details/44302635

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。

推薦閱讀更多精彩內容