iOS技术IOS网友们的篇章iOS开发超神学院

04.iOS远程推送通知 APNs远程推送,极光推送

2016-01-16  本文已影响3641人  Liwx

@(〓〓 iOS-实用技术)[远程/本地推送]


目录


1.远程推送通知

远程推送通知必须要真机调试,因为真机才有UDID,才能够生成deviceToken.应用的Bundle ID必须在苹果开发者中心创建,并且生成真机调试证书(.cer文件或.p12文件),推送通知调试证书(.cer文件或.p12文件)和profile描述文件(.mobileprovision文件).如果是要打包测试和发布,必须生成打包测试推送通知证书和发布推送通知证书.

01.真机调试证书和推送通知调试证书.png

远程推送的原理


2.远程推送通知实现, 客户端需要做的事


1.需要配置真机调试证书, 推送测试证书

注意: 必须要有付费版的开发者帐号才能配置生成证书.
配置证书参考教程: http://docs.jpush.io/client/ios_tutorials/#ios-8-uiusernotificationsettings


2.请求苹果获得deviceToken

注意: 只有真机可以调试推送通知
因为只有真机具备UDID, 才能够生成deviceToken

// ----------------------------------------------------------------------------
// 远程推送APNs必须使用真机调试,并且必须使用付费的开发者账号配置好对应的bundle ID和真机推送证书

- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions {
    
    // 向苹果请求DeviceToken
    [self requestDeviceToken];
    
    return YES;
}

// ------------------------------------------------------------------------
// 向苹果请求DeviceToken
- (void)requestDeviceToken
{
    // iOS 8.0之后必须请求授权
    if ([UIDevice currentDevice].systemVersion.floatValue >= 8.0) {
        
        // 1.请求授权
        UIUserNotificationSettings *setting = [UIUserNotificationSettings settingsForTypes:UIUserNotificationTypeBadge | UIUserNotificationTypeSound | UIUserNotificationTypeAlert categories:nil];
        [[UIApplication sharedApplication] registerUserNotificationSettings:setting];
        
        // 2.自动获取当前设备的UDID, 以及, app bundle id , 向苹果服务器发送请求, 获取deviceToken
        [[UIApplication sharedApplication] registerForRemoteNotifications];
    } else {
        // iOS 8.0之前不用请求授权
        // 2.自动获取当前设备的UDID, 以及, app bundle id , 向苹果服务器发送请求, 获取deviceToken
        [[UIApplication sharedApplication] registerForRemoteNotificationTypes:UIRemoteNotificationTypeBadge | UIRemoteNotificationTypeSound | UIRemoteNotificationTypeAlert];
    }
}
// ----------------------------------------------------------------------------
// 当我们调用对应的api, 发送请求, 获取deviceToken , 苹果服务器响应之后, 就会调用这个方法, 把deviceToken 传给我们
- (void)application:(UIApplication *)application didRegisterForRemoteNotificationsWithDeviceToken:(NSData *)deviceToken
{
    // 获取到DeviceToken时,将deviceToken值写入到第三方APNs推送服务器PushMeBaby(使用Socket编写的调试服务器),可以在GitHub上下载
    NSLog(@"%@", deviceToken);
}

3.远程推送服务端配置

在获得苹果返回的deviceToken后,发送deviceToken给公司的服务器.此处使用PushMeBaby模拟公司的服务器.PushMeBaby可以在GitHub上下载.
下载链接: https://github.com/stefanhafeneger/PushMeBaby

PushMeBaby的配置

02.真机测试证书改名为aps.cer.png 03.运行效果图.png
04.PushMeBaby设置deviceToken的两种方式.png

3.iOS客户端监听用户对通知的点击

监听远程推送通知点击的两种方法

// ----------------------------------------------------------------------------
// 监听远程推送通知点击(优先级较低),接收到通知,用户点击进入才会调用该方法
/**
 当接收到推送通知之后, 并且满足一下条件
 app 在前台时 ,会调用该方法
 app 从后台进入到前台 (App一开始在后台, app 锁屏),点击通知会调用该方法
 app 完全退出
 如果app 完全退出, 这时候,如果用户点击通知, 打开APP , 不会调用这个方法
 */
- (void)application:(UIApplication *)application didReceiveRemoteNotification:(NSDictionary *)userInfo;
// ----------------------------------------------------------------------------
// 监听远程推送通知点击(优先级较高),一接收到通知就会立即调用该方法
/**
    当接收到推送通知之后, 并且满足一下条件
    当我们实现, 这个方法时, 上面一个方法不再执行
    计时APP 完全退出, 也会调用这个方法
    completionHandler : 统计我们处理的时间, 耗电量, 刷新预览图片

    
    {"aps" :
        {
            "alert" : "This is some fancy message.",
            "badge":1,
            "content-available":"随便传"
        }
    }
*/

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

4.APNs远程推送实现的具体步骤

配置iOS应用的环境配置

05.真机调试证书,推送调试证书和描述文件profile.png

安装证书和描述文件后的效果图

06.安装证书和描述文件后的效果图.png
07.配置Bundle ID.png 08.设置开启应用的后台模式.png 09.配置开发者真机调试.png 10.配置开发者真机调试.png

APNs远程推送通知实现

// ----------------------------------------------------------------------------
// 远程推送APNs必须使用真机调试,并且必须使用付费的开发者账号配置好对应的bundle ID和真机推送证书
- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions {
    
    // 向苹果请求DeviceToken
    [self requestDeviceToken];
    
    return YES;
}

// ------------------------------------------------------------------------
// 向苹果请求DeviceToken
- (void)requestDeviceToken
{
    // iOS 8.0之后必须请求授权
    if ([UIDevice currentDevice].systemVersion.floatValue >= 8.0) {
        
        // 1.请求授权
        UIUserNotificationSettings *setting = [UIUserNotificationSettings settingsForTypes:UIUserNotificationTypeBadge | UIUserNotificationTypeSound | UIUserNotificationTypeAlert categories:nil];
        [[UIApplication sharedApplication] registerUserNotificationSettings:setting];
        
        // 2.自动获取当前设备的UDID, 以及, app bundle id , 向苹果服务器发送请求, 获取deviceToken
        [[UIApplication sharedApplication] registerForRemoteNotifications];
    } else {
        // iOS 8.0之前不用请求授权
        // 2.自动获取当前设备的UDID, 以及, app bundle id , 向苹果服务器发送请求, 获取deviceToken
        [[UIApplication sharedApplication] registerForRemoteNotificationTypes:UIRemoteNotificationTypeBadge | UIRemoteNotificationTypeSound | UIRemoteNotificationTypeAlert];
    }
}

// ----------------------------------------------------------------------------
// 当我们调用对应的api, 发送请求, 获取deviceToken , 苹果服务器响应之后, 就会调用这个方法, 把deviceToken 传给我们
- (void)application:(UIApplication *)application didRegisterForRemoteNotificationsWithDeviceToken:(NSData *)deviceToken
{
    // 获取到DeviceToken时,将deviceToken值写入到第三方APNs推送服务器PushMeBaby(使用Socket编写的调试服务器),可以在GitHub上下载
    NSLog(@"%@", deviceToken);
}

// ----------------------------------------------------------------------------
// 当获取DeviceToken失败是会调用该方法
- (void)application:(UIApplication *)application didFailToRegisterForRemoteNotificationsWithError:(NSError *)error
{
    NSLog(@"注册失败: %@", error.localizedDescription);
}

// ----------------------------------------------------------------------------
// 监听远程推送通知点击(优先级较低),接收到通知,用户点击进入才会调用该方法
/**
 当接收到推送通知之后, 并且满足一下条件
 app 在前台时 ,会调用该方法
 app 从后台进入到前台 (App一开始在后台, app 锁屏),点击通知会调用该方法
 app 完全退出
 如果app 完全退出, 这时候,如果用户点击通知, 打开APP , 不会调用这个方法
 */
- (void)application:(UIApplication *)application didReceiveRemoteNotification:(NSDictionary *)userInfo
{
    NSLog(@"接收到远程推送通知");
    
//    UISwitch *sw = [[UISwitch alloc] init];
//    [self.window.rootViewController.view addSubview:sw];
}

// ----------------------------------------------------------------------------
// 监听远程推送通知点击(优先级较高),一接收到通知就会立即调用该方法
/**
    当接收到推送通知之后, 并且满足一下条件
    当我们实现, 这个方法时, 上面一个方法不再执行
    计时APP 完全退出, 也会调用这个方法
    completionHandler : 统计我们处理的时间, 耗电量, 刷新预览图片

    效果: 当用户收到通知之后, 即使没有点击也会调用这个方法
    条件: 1 .需要勾选后台模式 remote notification,在后台
    2. 必须保证发送的推送通知格式, 包括  "content-available":"随便传"
    3. 执行completionHandler 回调代码块
    {"aps" :
        {
            "alert" : "This is some fancy message.",
            "badge":1,
            "content-available":"随便传"
        }
    }
*/

- (void)application:(UIApplication *)application didReceiveRemoteNotification:(NSDictionary *)userInfo fetchCompletionHandler:(void (^)(UIBackgroundFetchResult))completionHandler
{
    NSLog(@"fetchCompletionHandler: 接收到远程推送通知");
    
    UISwitch *sw = [[UISwitch alloc] init];
    [self.window.rootViewController.view addSubview:sw];
    
    
    completionHandler(UIBackgroundFetchResultNewData);
}

@end

PushMeBaby的配置

11.需要填写iPhone客户端向苹果请求对应的deviceToken.png 12.推送真机测试证书改名为aps.cer 拖入PushMeBaby项目.png

运行PushMeBaby和iPhone客户端程序

5.极光推送

第三方推送: 极光推送,个推,信鸽...
第三方服务合集: http://mdsa.51cto.com/services/

使用第三方推送的好处

优势
减少开发及维护成本:
应用开发者不需要去开发维护自己的推送服务器与 APNs 对接。
集成了 JPush iOS SDK 后不必自己维护更新 device token。
通过 JPush 的 Web Portal 直接推送,也可以调用JPush的 HTTP 协议 API 来完成,开发工作量大大减少。
减少运营成本:
极光推送支持一次推送,同时向 Android, iOS, WinPhone 三个平台。支持统一的 API 与推送界面。
极光推送提供标签、别名绑定机制,以及提供了非常细分的用户分群方式,运营起来非常简单、直观。
提供应用内推送:
除了使得 APNs 推送更简单,也另外提供应用内消息推送。这在类似于聊天的场景里很有必要。


极光推送介绍

13.极光推送发送通知流程图.png

极光推送的集成

链接: http://docs.jpush.io/guideline/ios_guide/

链接: http://docs.jpush.io/client/ios_tutorials/

链接: https://www.jpush.cn/common/products

上一篇 下一篇

猜你喜欢

热点阅读