推送随记
推送随记
小黑202 发表于1年前
推送随记
  • 发表于 1年前
  • 阅读 39
  • 收藏 0
  • 点赞 0
  • 评论 0

腾讯云 十分钟定制你的第一个小程序>>>   

1.有没有收到通知就立刻调用的方法

有的。如果您的App打开了background mode里的Remote Notifications项,那么当APNS的payload里指定content-available键为1时,且你的APP在后台或前台运行时/甚至你的App没有运行(但前提是用户没有通过强制关闭的方式关掉你的APP,也就是双击Home键能看到你的APP时),iOS会调用您app delegate里的

-(void)application:(UIApplication *)application didReceiveRemoteNotification:(NSDictionary *)userInfo fetchCompletionHandler:(void (^)(UIBackgroundFetchResult))completionHandler

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

3.补充:-(void)application:(UIApplication *)application didReceiveRemoteNotification:(NSDictionary *)userInfo不仅仅是用户点击推送进入app时候会被调用,用户在前台的时候收到推送通知的时候,推送不会显示,但是该过程也会被调用,所以需要在这个地方注意一下。可以判断一下程序是刚刚进入前台,还是已在前台。并选择是否通知viewController。

4.

如果程序通过点击推送启动,而非从后台唤醒,那么userInfo可以通过 -(BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions 这个代理方法里的 launchOptions[@"UIApplicationLaunchOptionsRemoteNotificationKey"] 得到

5.

- (void)application:(UIApplication *)application handleActionWithIdentifier:(NSString *)identifier forRemoteNotification:(NSDictionary *)userInfo withResponseInfo:(NSDictionary *)responseInfo completionHandler:(void (^)())completionHandler {

if ([identifier isEqualToString:foregroundActionidentifier]) {

NSLog(@"ios9点击了前台模式");

}

completionHandler();

}

6.App状态

根据application.applicationState的状态,判断执行哪种动作。

UIApplicationStateActive, // 激活状态,用户正在使用App
    UIApplicationStateInactive, // 不激活状态,用户切换到其他App、按Home键回到桌面、拉下通知中心
    UIApplicationStateBackground // 在后台运行

7.http://www.cocoachina.com/industry/20140528/8582.html

7.1用户看到消息之后,点击了一下action按钮或者点击了应用图标。如果action按钮被点击了,系统会通过调用application:didFinishLaunchingWithOptions:这个代理方法来启动应用,并且会把notification的payload数据传递进去。如果应用图标被点击了,系统也一样会调用application:didFinishLaunchingWithOptions:这个代理方法来启动应用,唯一不同的是这时候启动参数里面不会有任何notification的信息。

- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions 
{ 
    // do initializing works 
    ... 
     
    if (launchOptions) { 
        // do something else 
        ... 
     
        [AVAnalytics trackAppOpenedWithLaunchOptions:launchOptions]; 
    } 
     
    [application registerForRemoteNotificationTypes:UIRemoteNotificationTypeBadge | UIRemoteNotificationTypeAlert | UIRemoteNotificationTypeSound]; 
 
    return YES; 
} 

7.2

如果远程消息发送过来的时候,app正在运行,这时候会发生什么呢?

app代理的application:didReceiveRemoteNotification:方法会被调用,同时远程消息中的payload数据会作为参数传递进去。

- (void)application:(UIApplication *)application didReceiveRemoteNotification:(NSDictionary *)userInfo { 
    if (application.applicationState == UIApplicationStateActive) { 
        // 转换成一个本地通知,显示到通知栏,你也可以直接显示出一个alertView,只是那样稍显aggressive:) 
        UILocalNotification *localNotification = [[UILocalNotification alloc] init]; 
        localNotification.userInfo = userInfo; 
        localNotification.soundName = UILocalNotificationDefaultSoundName; 
        localNotification.alertBody = [[userInfo objectForKey:@"aps"] objectForKey:@"alert"]; 
        localNotification.fireDate = [NSDate date]; 
        [[UIApplication sharedApplication] scheduleLocalNotification:localNotification]; 
    } else { 
        [AVAnalytics trackAppOpenedWithRemoteNotificationPayload:userInfo]; 
    } 
} 

8.应用图标上红色数字消失,设置 UIApplication.applicationIconBadgeNumber 属性为0

一般我们会选择在应用启动的时候(application:didFinishLaunchingWithOptions:方法中),或者干脆一点,在应用每次被切换到前台的时候(applicationWillEnterForeground:方法中),调用这一行代码,即可立刻清除掉Badge数字了。

9.应用该怎么响应推送消息 

上面说的处理流程,只能简单展示一下远程消息,激活用户让他们重新回到app中来。但是有时候,我们希望带给用户更好的使用体验,譬如如果我们告诉用户:张三刚刚评论了你的照片。这时候用户如果点击action按钮进入app,我们是展示具体的评论页面为好,还是展示通常的启动页面然后让用户自己去找张三的评论好?我想负责任的开发者都会选择前者。

要做到灵活响应不同类型的通知消息,我们需要在通知的payload中增加更多信息,而不能仅仅只有alert出来的文字信息。对于AVOS Cloud消息推送平台来讲,就需要开发者使用更高级功能的JSON格式。譬如我们发送这样的json字符串{"action":{"type":4},"alert":"hello, everyone”} 最终在app内会收到这样的UserInfo Dictionary:

{ 
    action =     { 
        type = 4; 
    }; 
    aps =     { 
        alert = "hello, everyone"; 
        badge = 4; 
    }; 
} 

“hello, everyone”会显示到alertView中,但是整个Dictionary会通过launchOptions传递给application: didFinishLaunchingWithOptions: 方法,这样我们在程序里面就可以对不同的消息实现不同的跳转了。

共有 人打赏支持
粉丝 8
博文 98
码字总数 32894
×
小黑202
如果觉得我的文章对您有用,请随意打赏。您的支持将鼓励我继续创作!
* 金额(元)
¥1 ¥5 ¥10 ¥20 其他金额
打赏人
留言
* 支付类型
微信扫码支付
打赏金额:
已支付成功
打赏金额: