iOS 点击推送消息跳转指定界面 —总结篇app 在后台app被杀死

收到推送的准备:

首先至于说消息推送的原理,证书配置等等这些我在这里就不在累述,有很多写的很好的文章相信您已经可以搞定这块,这里我重点讲下各种情况下的跳转处理。

点击推送触发的几个方法:

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

 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 点击远程消息推送 *

/**
  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在前台收到消息时候,要 转成本地推送,然后点击本地推送的消息可以做相应的跳转。

我用的是个推的,在收到个推的透传消息时候会走这个代理方法,判断如果在前台的时候就转成本地推送

1.png

这个是转成本地推送的方法,当然对于里面数据的转换你要根据你们的业务需求和后台的返回情况做转化,因为你在之后点击本地推送的时候还是要根据你转本地推送所传的值进行对应的跳转的 - (void)requestLocationNotification:(NSDictionary *)payData{

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

希望这篇文章能够帮到你,总结的有点乱,有疑问的地方欢迎留言。

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏一“技”之长

iOS运用runtime全局修改UILabel的默认字体

        在项目比较成熟的基础上,遇到了这样一个需求,应用中需要引入新的字体,需要更换所有Label的默认字体,但是同时,对于一些特殊设置了字体的labe...

1155
来自专栏向治洪

ios入门之消息推送

前言 在去年的苹果大会上,苹果带来的iOS 10 系统中将之前繁杂的推送通知统一成UserNotifications.framework 来集中管理和使用通知功...

2126
来自专栏一“技”之长

Swift学习第二练——Swift项目时光电影

    很早以前的一个OC的练习项目,用swift重新写了一遍,因为xcode版本的更新对swift的兼容度也在不断改变,此版本适用于xcode6.1。

885
来自专栏逸鹏说道

AutoFac在项目中的应用

技能大全:http://www.cnblogs.com/dunitian/p/4822808.html#skill 完整Demo:https://github....

3576
来自专栏進无尽的文章

推送-JPush(极光推送)的使用

推送服务可以说是所有 App 的标配,不论是哪种类型的 App,推送都从很大程度上决定了 App 的 打开率、使用率、存活率 。因此,熟知并掌握推送原理及方法,...

7351
来自专栏iOS开发攻城狮的集散地

Url Scheme实现APP间通信、分享

接下来就以我之前写的UIActivityViewController系统原生分享-仿简书分享和iOS开源小项目-WSL两个Demo为例,让我们看下怎么可以让UI...

2458
来自专栏娱乐心理测试

iOS 如何把图片资源打包成bundle文件及遇到的坑(详解)

(1.)"Base SDK" 设置为 "Latest iOS (iOS 11.2)" (Xcode 9.2为例)

1962
来自专栏ShaoYL

程序启动的完整过程

45015
来自专栏iOS 开发杂谈

App的生命周期

注意: application:didFinishLaunchingWithOptions:: App 首次启动时调用,一般在这个函数里创建 window 对...

2151
来自专栏Rindew的iOS技术分享

iOS初步集成极光推送后你还要做这些事

3155

扫码关注云+社区