zoukankan      html  css  js  c++  java
  • 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。

     

  • 相关阅读:
    cocos进阶教程(5)回调函数和定时器的使用技巧
    lua关于参数生命周期的研究
    cocos进阶教程(5)各种动画使用心得
    Quick中require与import的区别
    【cocos2d-x 3.5】Lua动画API
    mac3.0环境搭建
    cocos-lua基础学习(10)scheduler类学习笔记
    LeetCode:搜索二维矩阵【74】
    LeetCode:搜索旋转排序数组【33】
    LeetCode:数据库技术【180-185】
  • 原文地址:https://www.cnblogs.com/csdnIOS/p/4881509.html
Copyright © 2011-2022 走看看