iOS集成极光推送之后,我还得这样做

首先我得承认,看着极光推送iOS SDK文档,然后集成到项目中这个过程并不难,难的是集成之后的事。

想要集成极光推送,简单来说就是那么几步:

  1. 打开应用的Push Notifications功能
  2. 创建Development证书
  3. 导出p12文件上传到极光推送后台
    如果需要在生产环境下推送通知的话,还需要4,5步骤
  4. 创建Production证书
  5. 导出p12文件上传到极光推送后台

就这样搞定了。当然这个前提是已经拥有App ID,并且已经配置好了相关的开发者证书和生产证书,然后在这个基础上添加Push Notifications功能。像我们公司,之前项目是没有这个功能的,最近才加上去的。

顺便说一下开发环境、生产环境及其对应关系:

  1. 开发环境:开发者证书-测试证书-Development证书(三种说法都一样)
  2. 生产环境:发布证书-生产证书-Production证书(三种说法都一样)
    开发环境证书和生产环境证书又有对应的Provisioning Profile描述文件。
    如果应用不上传到AppStore或者Ad Hoc(企业版账号)的话,只要1的相关证书就ok了。

如果还有不会集成的朋友可以看看JPush这个集成文档
http://docs.jiguang.cn/jpush/client/iOS/ios_sdk/
看了之后集成不成功的可以评论或者简信我,大家一起交流。


好了,上面先说这么多,接着说说集成成功之后要做的事。注意:以下操作都是在集成JPUSHService成功的前提下进行的。

大部分有推送功能的App都是这样一个设计,点击推送过来的通知跳转到其App对应的消息页面,比如社交类的简书:

财务类的中国建设银行:

下面说说根据程序不同运行状态,点击推送过来的通知,跳转到指定的页面。

我们这里暂时只讨论iOS 10之前的版本,如有朋友想做iOS 10的推送,可以看看下面这个链接
极光博客:http://blog.jiguang.cn/newfeture_notification_ios10/

JPush文档里有的代码就不说了,说它没有的。

/** 远程通知回调函数,只要点击了远程推送的消息就会走这个方法 */
- (void)application:(UIApplication *)application didReceiveRemoteNotification:(NSDictionary *)userInfo fetchCompletionHandler:(void (^)(UIBackgroundFetchResult))completionHandler {

    [JPUSHService handleRemoteNotification:userInfo];
    completionHandler(UIBackgroundFetchResultNewData);
    int badge =[userInfo[@"aps"][@"badge"] intValue];
    badge--;
    [JPUSHService setBadge:badge];
    [UIApplication sharedApplication].applicationIconBadgeNumber = badge; 
    // 上面几行是文档自带的

    /**
     *  iOS的应用程序分为3种状态
     *      1、前台运行的状态UIApplicationStateActive;
     *      2、后台运行的状态UIApplicationStateInactive;
     *      3、app关闭状态UIApplicationStateBackground。
     */

    // 1、应用正处在前台状态下,不会收到推送消息,这里创建一个UIAlertController来接受消息
    if (application.applicationState == UIApplicationStateActive) {
        NSLog(@"userInfo---:%@", userInfo);
        UIAlertController *alertvc = [UIAlertController alertControllerWithTitle:@"新消息" message:userInfo[@"aps"][@"alert"] preferredStyle:UIAlertControllerStyleAlert];
        UIAlertAction* updateAction = [UIAlertAction actionWithTitle:@"查看" style:UIAlertActionStyleDefault handler:^(UIAlertAction * _Nonnull action) {
            ActiveViewController *aVC = [[ActiveViewController alloc]initWithRemoteNotification:userInfo];
            UINavigationController *nav = (UINavigationController*) (self.window.rootViewController);
            [nav pushViewController:aVC animated:YES];
        }];
        UIAlertAction *cancelAction = [UIAlertAction actionWithTitle:@"取消" style:UIAlertActionStyleCancel handler:nil];
        [alertvc addAction:cancelAction];
        [alertvc addAction:updateAction];
        [self.window.rootViewController presentViewController:alertvc animated:YES completion:nil];
    } else if (application.applicationState == UIApplicationStateInactive) {
        // 处于后台运行状态时
        NSLog(@"---UIApplicationStateInactive---");
        InactiveViewController *ivc=[[InactiveViewController alloc]initWithRemoteNotification:userInfo];
        UINavigationController *nav = (UINavigationController*) (self.window.rootViewController);
        [nav pushViewController:ivc animated:NO];
    }
    // badge清零
    [application setApplicationIconBadgeNumber:0];
    [JPUSHService resetBadge];
}

当应用程序处于关闭状态时,也就是双击home键向上滑动退出应用。

/** 当应用一开始启动时会从这个方法开始运行程序 */
- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions {
    // ...此处省略部分代码

    // 添加下面几行代码,判断是不是点击消息进来的
    NSDictionary *remoteNotification = [launchOptions objectForKey: UIApplicationLaunchOptionsRemoteNotificationKey];
    if (remoteNotification) {  // 点击消息进来的
        BackgoundViewController *bVC = [[BackgoundViewController alloc]initWithRemoteNotification:remoteNotification];
        UINavigationController *nav = (UINavigationController*) (self.window.rootViewController);
        [nav pushViewController:bVC animated:NO];
        // 重置服务器端徽章
        [JPUSHService resetBadge];
    }

    return YES;
}
            前台运行
           后台运行

null

          退出状态

说明:
1.这里当应用程序处于关闭状态时,我上面在didFinishLaunchingWithOptions方法里做了处理,但是最后它又执行了后台运行时的方法,两个方法同时执行了,这个真不知道怎么回事?如果有朋友知道的话请留下评论,真心感激~~不过当我做本地通知的时候没有出现这样的情况,关闭状态它就跳到关闭时的页面,后台状态就是后台页面,不会同时执行。其实也不影响,一般的应用需求是点击通知跳到一个单独的消息页面,这里我做了三个不同状态下的三个页面(看到网上还有人说应用程序处于关闭状态是接受不了远程消息的,呵呵)。此处备注:Android手机,当app被杀死时,收不到消息

2.细心的朋友可能还发现应用名称不对应,桌面icon下面是NotificationDemo,而推过来的消息显示的是国付,这里我当时没注意,推送过来的消息显示的国付是在JPush后台设置的,设置之后生成的AppKey就和应用名称绑定了,不能更改。而我直接拿着AppKey做的这个demo,所以出现了这样的情况。

下面这个是当有消息推送过来,不去点击消息的情况,此时应用的右上角的徽章是不会去掉的。
null

           不点通知正常状态

小扩展:

  • 自定义推送消息声音。找一个aiff,wav,caf音频文件拖入到Xcode工程中,然后在后台推送通知时设置sound参数为对应的音频文件名称即可。
  • 应用徽章数字叠加。设置badge为+1,这样每推送一条消息,在用户没有点击的情况下就会自动加1.

最后想说一句,这个是第一次集成三方的sdk到公司项目中,算是总结吧!如果有不对的地方,还请各位朋友多指教,谢谢!在这里,希望和大家一起交流,共同进步。

原作者:顶起_那片天
原文链接:http://www.jianshu.com/p/a162ab50f6ed
著作权归作者所有,转载获得作者同意。