iOS 點擊推送消息跳轉指定界面 —總結篇

收到推送的準備:

首先至于說消息推送的原理,證書配置等等這些我在這里就不在累述,有很多寫的很好的文章相信您已經(jīng)可以搞定這塊,這里我重點講下各種情況下的跳轉處理。

點擊推送觸發(fā)的幾個方法:

ios7.0之前
- (void)application:(UIApplication *)application didReceiveRemoteNotification:(NSDictionary *)userInfo{
// App 收到推送的通知

 NSLog(@"********** ios7.0之前 **********");

if (application.applicationState == UIApplicationStateActive || application.applicationState == UIApplicationStateBackground) {
    
}
else
   {
    
    }
 }

ios 8 - 10 點擊本地推送 觸發(fā)的方法

/**
   ios 10 之前 點擊本地推送 觸發(fā)的方法

@param application
@param notification
 */
 -(void)application:(UIApplication *)application     didReceiveLocalNotification:(UILocalNotification *)notification{
DLog(@"本地通知 %ld",(long)application.applicationState );
// 用戶在前臺
if (application.applicationState == UIApplicationStateInactive ) {
    NSDictionary *dic = notification.userInfo;
    [self remoteNotificationWith:[dic objectForKey:@"payload"] ];
   }
  else
     {

     }
  }

*iOS 8 - 10 點擊遠程消息推送 *

/**
  iOS 8 - 10  
 @param application
 @param userInfo
 @param completionHandler
*/
  - (void)application:(UIApplication *)application    didReceiveRemoteNotification:(NSDictionary *)userInfo fetchCompletionHandler:(void (^)(UIBackgroundFetchResult))completionHandler
{


completionHandler(UIBackgroundFetchResultNewData);
// 打印到日志 textView 中
NSLog(@"********** iOS7.0之后 background **********");

[GeTuiSdk handleRemoteNotification:userInfo];
// 應用在前臺。
if (application.applicationState == UIApplicationStateActive) {
    {
        }
}
//后臺狀態(tài)下,直接跳轉到跳轉頁面。
if (application.applicationState == UIApplicationStateInactive ||  UIApplicationStateBackground)
{
    //后端推送
  
    if ([userInfo[@"payload"] isKindOfClass:[NSString class]]  ) {
        NSData *jsonData = [userInfo[@"payload"]  dataUsingEncoding:NSUTF8StringEncoding];
        [self remoteNotificationWith:[NSDictionary dictionaryWithJsonData:jsonData ]];
    }
      }


  }

*iOS10 之后點擊推送的方法 包括本地推送 *

/**
    ios 10 點擊消息推送的方法  包括點擊本地推送
 前端 點擊推送  后端 點擊推送
 @param center 、
 @param response 、
 @param completionHandler 、
*/
- (void)userNotificationCenter:(UNUserNotificationCenter *)center      didReceiveNotificationResponse:(UNNotificationResponse *)response   withCompletionHandler:(void(^)())completionHandler{
NSLog(@"********** iOS10.0之后  **********");
[[UIApplication sharedApplication] setApplicationIconBadgeNumber:0];
[GeTuiSdk resetBadge];
NSDictionary * userInfo =    response.notification.request.content.userInfo;

DLog(@"%@ %@",userInfo , [userInfo[@"payload"] class]);
if ([UIApplication sharedApplication].applicationState == UIApplicationStateActive) {

}
//后臺狀態(tài)下,直接跳轉到跳轉頁面。
 if ([UIApplication sharedApplication].applicationState == UIApplicationStateInactive ||  UIApplicationStateBackground)
 {

 }
 completionHandler(UNNotificationPresentationOptionAlert);  // 系統(tǒng)要求執(zhí)行這個 方法
}

做消息跳轉無外乎是在這幾個方法中,但是上面陳述的這些方法都只是針對系統(tǒng)版本做的分類,對于跳轉我們還要考慮下其他情況,點擊消息跳轉到指定的界面,這個時候要分3種情況
app 在前臺(轉本地推送)
=======

這個要根據(jù)你們的需求去做,我們的需求是app在前臺收到消息時候,要 轉成本地推送,然后點擊本地推送的消息可以做相應的跳轉。

我用的是個推的,在收到個推的透傳消息時候會走這個代理方法,判斷如果在前臺的時候就轉成本地推送

1.png

這個是轉成本地推送的方法,當然對于里面數(shù)據(jù)的轉換你要根據(jù)你們的業(yè)務需求和后臺的返回情況做轉化,因為你在之后點擊本地推送的時候還是要根據(jù)你轉本地推送所傳的值進行對應的跳轉的
- (void)requestLocationNotification:(NSDictionary *)payData{

if (IOS_VERSION >= 10) {
    //進行用戶權限的申請

    //通知內容類
    UNMutableNotificationContent * content = [UNMutableNotificationContent new];
    //設置通知請求發(fā)送時 app圖標上顯示的數(shù)字
    content.badge = @2;
    //設置通知的內容
    content.body = payData[@"content"];
    //默認的通知提示音
    content.sound = [UNNotificationSound defaultSound];
    //設置通知的副標題
   //        content.subtitle = @"這里是副標題";
    //設置通知的標題
    content.title = payData[@"title"];
    //設置從通知激活app時的launchImage圖片
    content.launchImageName = @"icon.png";
    content.userInfo = @{@"payload":payData};
    //設置5S之后執(zhí)行
    UNTimeIntervalNotificationTrigger * trigger = [UNTimeIntervalNotificationTrigger triggerWithTimeInterval:1 repeats:NO];
    UNNotificationRequest * request = [UNNotificationRequest requestWithIdentifier:@"NotificationDefault" content:content trigger:trigger];
   
    //添加通知請求
           [[ UNUserNotificationCenter currentNotificationCenter]      addNotificationRequest:request withCompletionHandler:^(NSError * _Nullable error) {
    }];
      }else{
         NSDictionary * userInfo = payData;
            UILocalNotification *notification=[[UILocalNotification alloc] init];
                        if (notification!=nil) {
                            UILocalNotification *notification = [[UILocalNotification alloc] init];
                            //設置1秒之后
                            NSDate *pushDate = [NSDate dateWithTimeIntervalSinceNow:1];
                            if (notification != nil) {
                                notification.fireDate = pushDate;
                                notification.timeZone = [NSTimeZone defaultTimeZone];
                                notification.repeatInterval = 0;
                                notification.soundName = UILocalNotificationDefaultSoundName;
                                if (userInfo[@"title"]) {
                                      notification.alertTitle = userInfo[@"title"];
                                }
                                if (userInfo[@"content"]) {
                                notification.alertBody = userInfo[@"content"];
                                }else{
                                notification.alertBody = @"您有新的消息";
                                 }                                    if (userInfo ) {
                                NSMutableDictionary *info = [NSMutableDictionary dictionaryWithObject:userInfo   forKey:@"payload"];
                                notification.userInfo = info;
                                }
                                DLog(@"%@  %@",userInfo , notification);
                                UIApplication *app = [UIApplication sharedApplication];
                                [app scheduleLocalNotification:notification];
                        
                            }
                            
                        }
                     }

  }

app 在前臺的時候當接收到消息推送的時候,如果你不做任何處理默認是不會有提示的,一般的處理方式就是透傳的消息轉化成本地消息推送,然后當用戶點擊的時候做相應的跳轉,當然也有可以直接做彈窗提醒,然后做對應的處理。

點擊本地推送觸發(fā)的方法

iOS 10之前

-(void)application:(UIApplication *)application didReceiveLocalNotification:(UILocalNotification *)notification

iOS 10 之后

- (void)userNotificationCenter:(UNUserNotificationCenter *)center didReceiveNotificationResponse:(UNNotificationResponse *)response withCompletionHandler:(void(^)())completionHandler

app 在后臺

app 在不是殺死狀態(tài) 這個時候點擊通知 會走如下方法

iOS 7之前
- (void)application:(UIApplication *)application didReceiveRemoteNotification:(NSDictionary *)userInfo

iOS 8 - 10
- (void)application:(UIApplication *)application didReceiveRemoteNotification:(NSDictionary *)userInfo fetchCompletionHandler:(void (^)(UIBackgroundFetchResult))completionHandler
ios 10之后
- (void)userNotificationCenter:(UNUserNotificationCenter *)center didReceiveNotificationResponse:(UNNotificationResponse *)response withCompletionHandler:(void(^)())completionHandler

這個時候你會發(fā)現(xiàn) 前臺后臺的時候走的可能是一個方法,在這里我們就要在方法中做下區(qū)分

3.png

app被殺死

這個時候會走didReceiveRemoteNotification這些的方法(有很多人認為不會走,經(jīng)過測試這個是會走的),但是這這里面寫跳轉什么的 ,就有點比較難處理了,因為didFinishLaunchingWithOptions這個方法沒有走,先走的didReceiveRemoteNotification再走的 didFinishLaunchingWithOptions 。這時候很多app的基本設置,比如做的跟視圖,自動登陸,等等很多的注冊什么的都還沒執(zhí)行,就直接跳轉這個是很麻煩的處理起來,所以在這里直接在下面的方法中做處理

- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions  
4.png

至此,這幾種情況就處理完了,總結下就是 app 在前臺,后臺,殺死,點擊推送為本地,遠端。 做不同的處理。
1.前臺在收到消息的時候做相應的處理比如轉本地推送,彈窗提醒等
2.后臺是在點擊消息的時候做處理(因為后臺的時候推送消息過來之后,的展示蘋果已經(jīng)幫我做好了,直接處理點擊挑戰(zhàn)就行了,當然如果是本地推送那是我們自己做處理的)
3.殺死的時候點擊消息啟動在 didFinishLaunchingWithOptions 做相應的跳轉處理。

希望這篇文章能夠幫到你,總結的有點亂,有疑問的地方歡迎留言。

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
【社區(qū)內容提示】社區(qū)部分內容疑似由AI輔助生成,瀏覽時請結合常識與多方信息審慎甄別。
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發(fā)布,文章內容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務。

相關閱讀更多精彩內容

  • Android 自定義View的各種姿勢1 Activity的顯示之ViewRootImpl詳解 Activity...
    passiontim閱讀 178,725評論 25 709
  • 極光推送: 1.JPush當前版本是1.8.2,其SDK的開發(fā)除了正常的功能完善和擴展外也緊隨蘋果官方的步伐,SD...
    Isspace閱讀 6,869評論 10 16
  • 發(fā)現(xiàn) 關注 消息 iOS 第三方庫、插件、知名博客總結 作者大灰狼的小綿羊哥哥關注 2017.06.26 09:4...
    肇東周閱讀 15,026評論 4 61
  • 資產(chǎn)重組
    若垂天云閱讀 166評論 0 0
  • 打包工具 Android打包工具,100個渠道包只需要10秒鐘 (packer-ng-plugin) 重要說明:1...
    北神GJH閱讀 9,763評論 1 4

友情鏈接更多精彩內容