Remote Notification(远程推送通知)

一、简介

1.概念
远程推送通知:顾名思义,就是从远程服务器推送给客户端的通知,即需要联网。
远程推送服务,又称为APNs(Apple Push Notification Services)

2.原因
使用远程推送通知的原因是传统获取数据的局限性,只要用户关闭了app,就无法跟app的服务器沟通,无法从服务器上获得最新的数据内容。而远程推送通知可以解决以上问题,不管用户打开还是关闭app,只要联网了,都能接收到服务器推送的远程通知。

二、远程推送实现

1.开发iOS程序的推送功能, iOS端需要做的事:

  • 请求APNs服务器获得deviceToken
  • 得到APNs服务器返回的deviceToken
  • 发送deviceToken给公司的服务器
  • 监听用户对通知的点击

2.代码演练

#import "AppDelegate.h"

@interface AppDelegate ()
@end

@implementation AppDelegate

// 客户端如果想接收APNs的远程推送通知,必须先注册(得到用户的授权),一般在App启动完毕后就马上注册
// 程序一启动就会调用
- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions {
    // iOS8及以后远程通知必须先注册设置
    if([[UIDevicecurrentDevice].systemVersiondoubleValue] >= 8.0) { // iOS8

        UIUserNotificationTypetype = UIUserNotificationTypeBadge| UIUserNotificationTypeSound| UIUserNotificationTypeAlert;

        UIUserNotificationSettings*settings = [UIUserNotificationSettingssettingsForTypes:type categories:nil];
     
        [application registerUserNotificationSettings:settings];
    } else { // iOS8以下版本
        UIRemoteNotificationTypetype = UIRemoteNotificationTypeBadge| UIRemoteNotificationTypeSound| UIRemoteNotificationTypeAlert;

        // 在注册app的Bundle ID时必须使用唯一的标识,不能用*,才可以有推送功能
        // iOS7中只需要注册通知类型就会同时注册了远程通知,iOS8及以后版本需要分别注册设置和注册通知
        // 只要执行了该句代码,就会自动向APNs服务器发送UUID和当前程序的Bundle ID请求DeviceToken
       [application registerForRemoteNotificationTypes:type];
    }
    returnYES;
}

// 注册成功推送设置时调用该方法
- (void)application:(UIApplication *)application didRegisterUserNotificationSettings:(UIUserNotificationSettings *)notificationSettings {
   if (notificationSettings !=nil) {
       // 注册远程通知——>用户授权——>允许接收远程推送
        [application registerForRemoteNotifications];
    }
}

// APNs服务器返回DeviceToken时调用
- (void)application:(UIApplication *)application didRegisterForRemoteNotificationsWithDeviceToken:(NSData *)deviceToken {
// 将deviceToken发送给三方服务器,三方服务器给APNs服务器发送远程推送请求,APNs推送至对应的移动设备
   NSLog(@"%@", deviceToken);
}

// 远程通知注册失败时调用
- (void)application:(UIApplication *)application didFailToRegisterForRemoteNotificationsWithError:(NSError *)error {
   NSLog(@"%@", error);
}

/*
 iOS7以前假的多任务:如果应用程序在后台, 只有用户点击了通知之后才会调用,如果应用程序在前台,会直接调用该方法, 即便应用程序关闭也可以接收到远程通知
 */
- (void)application:(UIApplication *)application didReceiveRemoteNotification:(NSDictionary
*)userInfo {

    // 该方法不能在后台刷新界面,只有用户点击进入应用(进入前台时会刷新界面)
   NSLog(@"%@", userInfo);
}

/* iOS7以后的真实多任务: 应用程序在前台或者后台,都会直接调用该方法,即便应用程序关闭也可以接收到远程通知
 */
// 一般使用这个方法代替上面的方法
- (void)application:(UIApplication *)application didReceiveRemoteNotification:(NSDictionary *)userInfo fetchCompletionHandler:(void (^)(UIBackgroundFetchResult))completionHandler {
   NSNumber *contentid = userInfo[@"content-id"];
   if (contentid) {
        //注意: 在此方法中一定要调用这个调用block, 告诉系统是否处理成功.
        // 以便于系统在后台更新UI等操作

        /*
          UIBackgroundFetchResultNewData, 成功接收到数据
          UIBackgroundFetchResultNoData, 没有;接收到数据
          UIBackgroundFetchResultFailed 接收失败
        */     
        completionHandler(UIBackgroundFetchResultNewData);
      } else
         {
           completionHandler(UIBackgroundFetchResultFailed);
         }
}
@end

三、调试iOS远程推送功能的必备条件

1.真机

2.调试推送需要的证书文件

  • aps_development.cer : 某台电脑就能调试某个app的推送服务
  • ios_development.cer : 让电脑具备真机调试的能力(调试设备)
  • iphone6_qq.mobileprovision : 某台电脑就能利用某台设备调试某个程序

四、发布具有远程推送服务的app

  • aps_production.cer : 如果发布的程序中包含了推送服务,就必须安装这个证书
  • ios_distribution.cer : 让电脑具备发布程序的能力
  • qq.mobileprovision : 某台电脑就能发布某个程序

你可能感兴趣的:(Remote Notification(远程推送通知))