IOS 处理消息推送,并跳转到相关界面

如果你的程序在未启动的时候,如果用户点击通知,notification会通过didFinishLaunchingWithOptions:传递给您,如果用户未点击通知,则didFinishLaunchingWithOptions:的字典里不会有notification的信息,同理,如果你的程序正在后台运行,如果用户点击通知,则(void)application:(UIApplication *)application didReceiveRemoteNotification:(NSDictionary *)userInfo会在你的程序进入前台后才会被调用(注意是通过点按通知启动才会被调用)如果用户收到了通知但是没有点按通知,而是点击屏幕上的App图标进入的app,则(void)application:(UIApplication *)application didReceiveRemoteNotification:(NSDictionary *)userInfo不会被调用,里面的代码不会被执行。

下面回答你的问题,看你的代码应该是你知道了通过通知启动未在后台运行的App这种情况下如何加载你的userinfo,你是通过ViewController的viewDidLoad来查询AppDelegate的push属性,并加载其中的内容。不过我认为你这么做是有问题的。以为viewDidLoad会先于application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions执行,所以你的viewDidLoad方法执行的时候由于application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions尚未执行,得到push属性应该是nil。不知道您有没有注意这个问题,所以不建议你这么做。正确的做法我认为应该是:
1)为你的AppDelegate添加一个viewController类型的弱引用成员变量或者属性(比如@property (weak, nonatomic) viewController *mainViewController;
2) 在你的viewDidLoad委托方法里将上述属性设置为自身( appDelegate.mainViewController=self;  )
3) 为你的viewController创建一个公开的方法,用以AppDelegate发送消息告知viewController内容有更新
//  viewController.h
@interface viewController : NSViewController
.....
-(void)updateForNotification;
....
@end

// viewController.m
@implementation viewController
......
-(void)updateForNotification {
    NSString *url = [[NSString alloc] init];
    RKAppDelegate *appDelegate = [[UIApplication sharedApplication] delegate];
    url = [ NSString stringWithFormat:@"%@", appDelegate.push];
    if ([url isEqual:@"(null)"])
    {
        [self.webViewDelegate loadUrl:@"http://www.baidu.com"];
    }else{
        [self.webViewDelegate loadUrl:url];
        appDelegate.push = nil;
    }
}
.....

@end
4) 最后要做的就是AppDelegate在合适的时机发送这个消息,也就是在两个预通知有关的委托方法里处理自己的push并调用mainViewController的updateForNotification方法。
- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions{
    if (launchOptions) {
         NSString *pushString =  [NSString stringWithFormat:@"%@", launchOptions];
        RKAppDelegate *appDelegate = [[UIApplication sharedApplication] delegate];
        NSString *url= [[launchOptions objectForKey:@"UIApplicationLaunchOptionsRemoteNotificationKey"] objectForKey:@"url"];
        appDelegate.push= url;

       [_mainViewController updateForNotification];

    }
}


- (void)application:(UIApplication *)application didReceiveRemoteNotification:(NSDictionary *)userInfo {
    // 处理你的userinfo并将需要的信息赋值给appDelegate的push属性
.............Your code here..........

   [_mainViewController updateForNotification];
    
}



补充一下,(void)application:(UIApplication *)application didReceiveRemoteNotification:(NSDictionary *)userInfo不仅仅是用户点击推送进入app时候会被调用,用户在前台的时候收到推送通知的时候,推送不会显示,但是该过程也会被调用,所以需要在这个地方注意一下。可以判断一下程序是刚刚进入前台,还是已在前台。并选择是否通知viewController。
[
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值