收到推送的准备:
首先至于说消息推送的原理,证书配置等等这些我在这里就不在累述,有很多写的很好的文章相信您已经可以搞定这块,这里我重点讲下各种情况下的跳转处理。
点击推送触发的几个方法:
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在前台收到消息时候,要 转成本地推送,然后点击本地推送的消息可以做相应的跳转。
我用的是个推的,在收到个推的透传消息时候会走这个代理方法,判断如果在前台的时候就转成本地推送
这个是转成本地推送的方法,当然对于里面数据的转换你要根据你们的业务需求和后台的返回情况做转化,因为你在之后点击本地推送的时候还是要根据你转本地推送所传的值进行对应的跳转的
- (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
这个时候你会发现 前台后台的时候走的可能是一个方法,在这里我们就要在方法中做下区分
app被杀死
这个时候会走didReceiveRemoteNotification这些的方法(有很多人认为不会走,经过测试这个是会走的),但是这这里面写跳转什么的 ,就有点比较难处理了,因为didFinishLaunchingWithOptions这个方法没有走,先走的didReceiveRemoteNotification再走的 didFinishLaunchingWithOptions 。这时候很多app的基本设置,比如做的跟视图,自动登陆,等等很多的注册什么的都还没执行,就直接跳转这个是很麻烦的处理起来,所以在这里直接在下面的方法中做处理
- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions
至此,这几种情况就处理完了,总结下就是 app 在前台,后台,杀死,点击推送为本地,远端。 做不同的处理。
1.前台在收到消息的时候做相应的处理比如转本地推送,弹窗提醒等
2.后台是在点击消息的时候做处理(因为后台的时候推送消息过来之后,的展示苹果已经帮我做好了,直接处理点击挑战就行了,当然如果是本地推送那是我们自己做处理的)
3.杀死的时候点击消息启动在 didFinishLaunchingWithOptions 做相应的跳转处理。
希望这篇文章能够帮到你,总结的有点乱,有疑问的地方欢迎留言。