推送通知

本地 推送通知

  • “本地”可以理解为”不联网”;即使没有网络情况下,也可以推送通知消息
  • 应用场景: 确定知道未来某个时间点应该提醒用户什么
  • 设置一些必要属性
设置一些必要属性
// 推送通知的触发时间(何时发出推送通知)
@property(nonatomic,copy) NSDate *fireDate;
// 推送通知的具体内容
@property(nonatomic,copy) NSString *alertBody;
// 在锁屏时显示的动作标题(完整标题:“滑动来” + alertAction)
@property(nonatomic,copy) NSString *alertAction;
// 音效文件名
@property(nonatomic,copy) NSString *soundName;
// app图标数字
@property(nonatomic) NSInteger applicationIconBadgeNumber;

一、 开始推送通知

  • 根据fireDate设定的时间进行推送

    [[UIApplication sharedApplication] scheduleLocalNotification:ln];
    
- 立即推送
```objc         
presentLocalNotificationNow:(UILocalNotification *)notification;

二、 监听用户点击通知

  • app处于前台
    此时不会弹框通知用户通知的到达,但是还是会调用对应的代理方法
  • app并没有关闭,一直隐藏在后台时
    此时用户点击通知信息后,会让app进入前台,并会调用AppDelegate的下面方法
application: didReceiveLocalNotification: 
  • app已经被关闭(进程已死)
    此时用户点击通知信息后,会启动app,启动完毕会调用AppDelegate的下面方法
//launchOptions参数通过UIApplicationLaunchOptionsLocalNotificationKey取出本地推送通知对象
application: didFinishLaunchingWithOptions: 

三、额外设置

        // 每隔多久重复发一次推送通知
        @property(nonatomic) NSCalendarUnit repeatInterval;
        // 点击推送通知打开app时显示的启动图片
        @property(nonatomic,copy) NSString *alertLaunchImage;
         // 附加的额外信息
        @property(nonatomic,copy) NSDictionary *userInfo;
        // 时区
        @property(nonatomic,copy) NSTimeZone *timeZone;
        (一般设置为[NSTimeZone defaultTimeZone] ,跟随手机的时区)

四、 其他操作

  • 获得被调度(定制)的所有本地推送通知
@property(nonatomic,copy) NSArray *scheduledLocalNotifications;
//已经发出且过期的推送通知就算调度结束,会自动从这个数组中移除

  • 取消调度本地推送通知
- (void)cancelLocalNotification:(UILocalNotification *)notification;
- (void)cancelAllLocalNotifications;

五、 注意事项

  • 在iOS 8.0+,如果要使用本地通知,需要得到用户的许可
    在didFinishLaunchingWithOptions方法中添加如下代码
 UIUserNotificationSettings *settings = [UIUserNotificationSettings settingsForTypes:UIUserNotificationTypeBadge | UIUserNotificationTypeSound | UIUserNotificationTypeAlert categories:nil];
 [application registerUserNotificationSettings:settings];

六、额外补充

  • 在iOS8.0之后,可以设置推送通知带操作行为
    在注册设置时,设置categories:参数
  • 监听通知操作行为的点击
推送通知_第1张图片
注册通知.png
推送通知_第2张图片
基本操作.png
监听本地通知的状态.png
推送通知_第3张图片
设置通知的快捷操作组.png
推送通知_第4张图片
跳转不同界面.png

远程 推送通知
所有苹果设备, 在联网状态下,都会与苹果服务器建立一个长连接

  • 短连接
    “短连接”优势:节省资源,一个会话结束后,立即释放资源
    劣势: 服务器无法主动向客户端发信息

  • 长连接
    “长连接”优势: 服务器可以向客户端发送信息,保证数据即时性
    劣势: 占用客户和服务器资源
    作用: 时间校准,系统升级,查找我的iPhone,推送通知...

  1. 创建支持远程推送功能的App ID
  2. 申请开发者证书,并选中刚刚创建的App ID
  3. 下载CER文件,并导入钥匙串管理
  4. 申请发布证书,并选中刚刚创建的App ID
  5. 下载CER文件,并导入钥匙串管理
  6. 检查App ID,确认证书已经指定
格式:{"aps":{"alert":"This is some fancy message.","badge":1,"sound":"default"}}

远程推送应用程序开发过程
1.新建应用程序

  1. 指定AppID,在developer.apple.com上设置的AppID
#ifdef __IPHONE_8_0
    // 注册接收通知的类型
    UIUserNotificationSettings *settings = [UIUserNotificationSettings settingsForTypes:UIUserNotificationTypeAlert | UIUserNotificationTypeBadge | UIUserNotificationTypeSound categories:nil];
    [application registerUserNotificationSettings:settings];
    
    // 注册允许接收远程推送通知
    [application registerForRemoteNotifications];
#else
    // 如果是iOS7.0,使用以下方法注册
    [application registerForRemoteNotificationTypes:UIUserNotificationTypeAlert | UIUserNotificationTypeBadge | UIUserNotificationTypeSound];
#endif


// 当得到苹果的APNs服务器返回的DeviceToken就会被调用
// 7040f7d5 5a974598 c5cf31b5 3e340b39 68affd25 122f0ce1 3f315226 396c2e5b
- (void)application:(UIApplication *)application didRegisterForRemoteNotificationsWithDeviceToken:(NSData *)deviceToken {
    NSLog(@"deviceToken是:%@", deviceToken);
}

// 接收到远程通知,触发方法和本地通知一致
- (void)application:(UIApplication *)application didReceiveRemoteNotification:(NSDictionary *)userInfo {
    NSLog(@"%@", userInfo);
}

** 使用后台的远程消息推送**

1、在Capabilities中打开远程推送通知
2、实现代理方法

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

远程消息数据格式:
{"aps" : {"content-available" : 1},"content-id" : 42}
执行completionHandler有两个目的
1、统会估量App消耗的电量,并根据传递的UIBackgroundFetchResult 参数记录新数据是否可用
2、 调用完成的处理代码时,应用的界面缩略图会自动更新

注意:接收到远程通知到执行完网络请求之间的时间不能超过30秒

if (userInfo) {
    int contentId = [userInfo[@"content-id"] intValue];
    
    ViewController *vc = (ViewController *)application.keyWindow.rootViewController;
    [vc loadDataWithContentID:contentId completion:^(NSArray *dataList) {
        vc.dataList = dataList;
        
        NSLog(@"刷新数据结束");
        
        completionHandler(UIBackgroundFetchResultNewData);
    }];
} else {
    completionHandler(UIBackgroundFetchResultNoData);
}

你可能感兴趣的:(推送通知)