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

收到推送的準備:前端

首先至於說消息推送的原理,證書配置等等這些我在這裏就不在累述,有不少寫的很好的文章相信您已經能夠搞定這塊,這裏我重點講下各類狀況下的跳轉處理。
複製代碼

####點擊推送觸發的幾個方法:ios

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

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

if (application.applicationState == UIApplicationStateActive || application.applicationState == UIApplicationStateBackground) {
    
}
else
   {
    
    }
 }
複製代碼

ios 8 - 10 點擊本地推送 觸發的方法後端

/**
   ios 10 以前 點擊本地推送 觸發的方法

@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 點擊遠程消息推送 *app

/**
  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) {
    {
        }
}
//後臺狀態下,直接跳轉到跳轉頁面。
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) {

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

 }
 completionHandler(UNNotificationPresentationOptionAlert);  // 系統要求執行這個 方法
}
複製代碼

作消息跳轉無外乎是在這幾個方法中,可是上面陳述的這些方法都只是針對系統版本作的分類,對於跳轉咱們還要考慮下其餘狀況,點擊消息跳轉到指定的界面,這個時候要分3種狀況 app 在前臺(轉本地推送)

這個要根據大家的需求去作,咱們的需求是app在前臺收到消息時候,要 轉成本地推送,而後點擊本地推送的消息能夠作相應的跳轉。fetch

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

1.png

這個是轉成本地推送的方法,固然對於裏面數據的轉換你要根據大家的業務需求和後臺的返回狀況作轉化,由於你在以後點擊本地推送的時候仍是要根據你轉本地推送所傳的值進行對應的跳轉的 - (void)requestLocationNotification:(NSDictionary *)payData{spa

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

    //通知內容類
    UNMutableNotificationContent * content = [UNMutableNotificationContent new];
    //設置通知請求發送時 app圖標上顯示的數字
    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以後執行
    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 在前臺的時候當接收到消息推送的時候,若是你不作任何處理默認是不會有提示的,通常的處理方式就是透傳的消息轉化成本地消息推送,而後當用戶點擊的時候作相應的跳轉,固然也有能夠直接作彈窗提醒,而後作對應的處理。代理

點擊本地推送觸發的方法

iOS 10以前

-(void)application:(UIApplication *)application didReceiveLocalNotification:(UILocalNotification *)notification
複製代碼

iOS 10 以後

- (void)userNotificationCenter:(UNUserNotificationCenter *)center didReceiveNotificationResponse:(UNNotificationResponse *)response withCompletionHandler:(void(^)())completionHandler
複製代碼

app 在後臺

app 在不是殺死狀態 這個時候點擊通知 會走以下方法

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

這個時候你會發現 前臺後臺的時候走的多是一個方法,在這裏咱們就要在方法中作下區分

3.png

app被殺死

這個時候會走didReceiveRemoteNotification這些的方法(有不少人認爲不會走,通過測試這個是會走的),可是這這裏面寫跳轉什麼的 ,就有點比較難處理了,由於didFinishLaunchingWithOptions這個方法沒有走,先走的didReceiveRemoteNotification再走的 didFinishLaunchingWithOptions 。這時候不少app的基本設置,好比作的跟視圖,自動登錄,等等不少的註冊什麼的都還沒執行,就直接跳轉這個是很麻煩的處理起來,因此在這裏直接在下面的方法中作處理

- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions  
複製代碼

4.png

至此,這幾種狀況就處理完了,總結下就是 app 在前臺,後臺,殺死,點擊推送爲本地,遠端。 作不一樣的處理。 1.前臺在收到消息的時候作相應的處理好比轉本地推送,彈窗提醒等 2.後臺是在點擊消息的時候作處理(由於後臺的時候推送消息過來以後,的展現蘋果已經幫我作好了,直接處理點擊挑戰就好了,固然若是是本地推送那是咱們本身作處理的) 3.殺死的時候點擊消息啓動在 didFinishLaunchingWithOptions 作相應的跳轉處理。

但願這篇文章可以幫到你,總結的有點亂,有疑問的地方歡迎留言。

相關文章
相關標籤/搜索