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 作相应的跳转处理。

但愿这篇文章可以帮到你,总结的有点乱,有疑问的地方欢迎留言。

相关文章
相关标签/搜索