假如你已经集成完了极光,恰好有这个问题不知如何解决,可以看看这篇文章,这篇是针对远程通知的,本地通知大同小异吧。
根据我项目的要求,极光推送跳转指定页面分为两种情况:app在后台情况和app在杀死的情况下。app在前台跳转页面暂时没做过。
-.杀死app情况
这种情况app是由推送消息唤醒的,app启动就必须触发这个方法:
- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions ;
判断app是否是由推送消息唤醒的,看下面:
把这个写在上面的方法中即可。但是有时候可能会出问题。下面有方法解决。
if (launchOptions) { //是否有推送消息
NSDictionary *remoteNotification = [launchOptions objectForKey: UIApplicationLaunchOptionsRemoteNotificationKey]; //这是判断app是否是由远程通知启动的 若是由本地通知启动的 则把 UIApplicationLaunchOptionsRemoteNotificationKey 换成 UIApplicationLaunchOptionsLocalNotificationKey
if (remoteNotification) { //是否有远程推送消息
[self jumpToViewctroller:remoteNotification]; //这是跳转页面的方法。
}
}
//跳转方法
-(void)jumpToViewctroller:(NSDictionary *)remoteNotification{
//remoteNotification是消息的json格式,跳转指定控制器首先你需要跟后台商量一下,添加一个字段。我这里添加的是jump,如果是1跳转这个,是2的话跳转那个等等。
if ([[NSString stringWithFormat:@"%@",remoteNotification[@"jump"]] isEqualToString:@"1"]) {
//这里注意一下。大多数页面都是UINavigationController的子控制器。当然了,在这里你是不能push进去的。必须present进去。此时你可能会问,那存储一个key值present是干什么用的。哈哈,这是告诉你要跳转的控制器,我是被present进来的。所以我返回的时候你也要把我diss回去。同时你也要清除它。
/*
控制器的返回方法。
if ([[[NSUserDefaults standardUserDefaults] objectForKey:@"present"] isEqualToString:@"1"]) {
[self dismissViewControllerAnimated:YES completion:^{
[[NSUserDefaults standardUserDefaults] setObject:@"" forKey:@"present"]; // 这里最好完全清除它。
}];
}else{
[self.navigationController popViewControllerAnimated:YES];
}
*/
DelivedViewController *VC = [DelivedViewController new];
[[NSUserDefaults standardUserDefaults] setObject:@"1" forKey:@"present"] ;
[[NSUserDefaults standardUserDefaults] synchronize];
UINavigationController *na = [[UINavigationController alloc] initWithRootViewController:VC];
[self.window.rootViewController presentViewController:na animated:YES completion:nil];
}
}
以上就是app未运行的情况下跳转页面的。 注意: 前面说了判断是否有推送消息可能有问题。我遇到的问题就是 程序奔溃。可以让它延迟执行,方法如下:
- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions {
// 忽略 。。。。。。
[self performSelector:@selector(sendNotation:) withObject:launchOptions afterDelay:1.5];
return YES;
}
-(void)sendNotation:(NSDictionary *)launchOptions{
if (launchOptions) {
NSDictionary *remoteNotification = [launchOptions objectForKey: UIApplicationLaunchOptionsRemoteNotificationKey];
if (remoteNotification) {
[self jumpToViewctroller:remoteNotification];
}
}
}
这样就ok了。
二,app在后台运行情况。
这种情况就非常简单了。 上代码!
// iOS 10 Support 程序在后台时收到通知,点击通知栏进入app
- (void)jpushNotificationCenter:(UNUserNotificationCenter *)center didReceiveNotificationResponse:(UNNotificationResponse *)response withCompletionHandler:(void (^)())completionHandler {
// Required
NSDictionary * userInfo = response.notification.request.content.userInfo;
if([response.notification.request.trigger isKindOfClass:[UNPushNotificationTrigger class]]) {
//UNPushNotificationTrigger 远程(通知类型)
[JPUSHService handleRemoteNotification:userInfo];//userInfo消息数据,包含jump。
if ([UIApplication sharedApplication].applicationState == UIApplicationStateInactive ) {
[self jumpToViewctroller:userInfo];
[UIApplication sharedApplication].applicationIconBadgeNumber = 0; //本地消息清0
[JPUSHService setBadge:0];//极光消息清0
}
}
completionHandler(); // 系统要求执行这个方法
}
- (void)application:(UIApplication *)application didReceiveRemoteNotification:(NSDictionary *)userInfo fetchCompletionHandler:(void (^)(UIBackgroundFetchResult))completionHandler {
// Required, iOS 7 Support
[JPUSHService handleRemoteNotification:userInfo];
if ([UIApplication sharedApplication].applicationState == UIApplicationStateInactive ) {
[self jumpToViewctroller:userInfo];
[UIApplication sharedApplication].applicationIconBadgeNumber = 0;
[JPUSHService setBadge:0];
}
completionHandler(UIBackgroundFetchResultNewData);
}
好了,以上就是全部内容,本人小白一枚,难免有理解不到位的地方,请各位大佬指正。谢谢!