iOS集成个推小结

作者: _浅墨_ | 来源:发表于2016-04-20 19:16 被阅读3738次
一、以下为我集成时的问题与解决方案:

1、iOS通知,在官网后台怎么推送,不能单独推送通知?

iOS只能透传消息,个推开发人员说,是因为苹果的要走apns,而第一个默认的推送是走的个推服务器。

2、如果应用在前台处于运行状态,是不是不走APNs
这个是怎么实现的?实时监控应用是否在线?

判断clientid和个推服务器的连接状态。简单说就是客户端sdk和个推服务器是否是连接状态的。

3、字符串 字典 远程通知 区别 使用场景?

字符串是apn的简单推送
字典和远程通知是apn的高级推送
字符串和字典会有apn通知栏提示,远程通知没有

4、为了更好支持SDK推送,APP定期抓取离线数据,需要配置后台运行权限:Backgound fetch:后台获取Remote notifications: 推送唤醒(静默推送,Silent Remote Notifications) 这个设置与不设置的区别?

这个不设置也没关系的

5、clientid(CID)与 devictoken

devictoken是向苹果注册的,clientid(CID)是个推这边推送消息用到的,devicetoken是推送APNS消息用到的,客户端集成后会获取clientid,我们会判断clientid和个推服务器的连接状态。简单说就是客户端sdk和个推服务器是否是连接状态的。客户端clientid和devictoken会有一个绑定关系,我们系统会维护这个绑定关系。

6、缓存消息存在问题(消息中心)
如果缓存apns通知,用户点击icon进入应用获取不到通知内容,这个时候会消息丢失如果缓存透传消息内容,超出离线时间(最长可设置72小时),再打开应用,这个时候也获取不到透传消息,这样就存在问题了,超出离线时间,无论缓存透传消息内容还是apns通知,都不会有可缓存内容。

个推技术支持给的解决方案:
收到的消息保存在数据库里,超过离线时间没有下发的用户,当他点击图标打开应用,或者进入历史消息页面进行查看时,客户端可以主动的去向服务器拉取数据,这些数据你们是会在服务器中保存的。就是你们客户端向你们的服务器上去获取数据,不走推送了。客户端向服务端发送请求,然后服务端把数据返回给客户端比如银行账单也是这样的,用户在页面中进行下拉时,会去刷新页面,此时就是去服务器上重新提取的数据。

7、问题:
程序第一次启动的时候,即由死亡状态进入激活状态,这个时候接收到通知,点击条幅通知,
要根据通知内容进行页面跳转,但这个时候项目文件还没加载完全,不能跳转,之前我们的
实现方法是这样的,在didFinishLaunchingWithOptions代理下面添加如下方法

// 程序在死亡状态,再次启动,收到推送通知,跳转至对应页面
if ([launchOptions objectForKey:UIApplicationLaunchOptionsRemoteNotificationKey]) {
    NSDictionary * userInfo = [launchOptions objectForKey:UIApplicationLaunchOptionsRemoteNotificationKey];
    self.notificationUserInfo = userInfo;
    // 这里延迟1秒 否则不执行跳转
    [self performSelector:@selector(skipToMessageCenter) withObject:nil afterDelay:1];
}

现在换成个推后要5秒后才能跳转

[self performSelector:@selector(skipToMessageCenter) withObject:nil afterDelay:5];

这个延迟时间无法准确计算,所以上面方法是有缺陷的,那么有没更好的解决方案呢?
答案是有的,以下为我优化方案。如果你有更好的方法,欢迎指正。

AppDelegate.m:

- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions {
    
        // 程序在死亡状态,再次启动,收到推送通知,跳转至对应页面
    if ([launchOptions objectForKey:UIApplicationLaunchOptionsRemoteNotificationKey]) {
        NSDictionary * userInfo = [launchOptions objectForKey:UIApplicationLaunchOptionsRemoteNotificationKey];
        self.notificationUserInfo = userInfo;
        // 缓存apns通知内容到本地
        [[NSUserDefaults standardUserDefaults]setObject:self.notificationUserInfo forKey:KRemoteNotificationUserInfo];
        [[NSUserDefaults standardUserDefaults ]synchronize];
        
        [[NSNotificationCenter defaultCenter] addObserver:self selector:@selector(skipToMessageCenter) name:KReciveRemoteNotificationUserInfo object:nil];
    }
}

-(void)skipToMessageCenter {
    
    dispatch_async(dispatch_get_main_queue(), ^{
        // 根据通知内容,跳转至不同页面
        MessageModel * messageModel = [[MessageModel alloc] initWithNoticeDic:self.notificationUserInfo];
        MessageToSpecificViewController * messageToSpecificViewController = [[MessageToSpecificViewController alloc] init];
        [messageToSpecificViewController messageFromViewController:update.mainViewController toSpecificViewControllerWithMessage:messageModel];
        self.notificationUserInfo = nil;
    });
}

MainViewController.m:

-(void)viewDidAppear:(BOOL)animated{
    [super viewDidAppear:animated];
   
    // 应用由死亡状态进入激活状态,这个时候发送通知,appdelegate接受通知,根据通知内容进行不同跳转
    NSDictionary * notificationUserInfo =[[NSUserDefaults standardUserDefaults]valueForKey:KRemoteNotificationUserInfo];
    if (notificationUserInfo) {
        [[NSNotificationCenter defaultCenter] postNotificationName:KReciveremoteNotificationUserInfo object:nil];
        
        [[NSUserDefaults standardUserDefaults]setObject:nil forKey:KRemoteNotificationUserInfo];
        [[NSUserDefaults standardUserDefaults ]synchronize];
    }
}

8、设置别名

使用别名进行单点推送。
之前做极光推送的时候,我们别名使用的是[[UIDevice currentDevice] getCurrentDeviceUUID],这个Id不能直接使用,因为不符合格式,我把分隔符-换成了分隔符_,这样是可以的。
原以为UUID全球唯一,请教了下同事,同事说这个id会变的,就是不同证书,即使同一台设备,UUID也会不一样。
个推的小伙伴给的建议是,别名使用clientId,�它是对应每台设备唯一的。但是如果使用clientId,就又存在一个用户登录多台设备,使用clientId单点推送就存在问题。解决方法,可以使用useId做别名。

/** SDK启动成功返回cid */
- (void)GeTuiSdkDidRegisterClient:(NSString *)clientId {
    //个推SDK已注册,返回clientId
    NSLog(@"\n>>>[GeTuiSdk RegisterClient]:%@\n\n", clientId);
    // 绑定别名
    [GeTuiSdk bindAlias:advertisingUUID];
    NSLog(@"个推别名======%@",advertisingUUID);
}

9、关于下发率:

10%的下发率确实不高,离线时间设置的比较短,可以设置长一点,整个大盘的下发率在20-40%左右。
iOS的如果不设置离线时间,个推这边是不会下发APNS消息的。应用在手机上,至少要打开一次,初始化成功SDK,获取到CID,这样才可以推送。
如果后面一直没有打开,离线时间也设置了,个推会推送APNS消息下发。
离线时间是针对离线用户的,推送下发的时候,在线的用户消息就直接推送到客户端了,离线的用户,消息会作为离线消息存在离线库里,离线用户在离线时间内在线,离线消息就会下发。
只有在离线时间内打开过应用才统计下发率。
用户离线情况如,用户进程是关闭的,网络是断开等...
iOS的下发统计的是应用打开后,走个推长连接通道下发的透传消息的下发。
比如说一个用户收到了apn通知,用户在2小时(设置的离线时间为2小时)内都没有打开过app,那这个透传消息就不会下发了,对应的就统计不到了。
也就是说,如果我设置离线时间2小时,应用进程关闭或者应用在后台,通知到来,两个小时后我再打开应用,这个时候不会走个推的代理方法收到透传消息。

10、 iOS同一台设备,中文环境下先打了“中文”标签,切换到英文环境后再打“英文”标签,这时候在个推后台中心向“中文”标签进行推送,英文环境同样收到了中文通知,有解决办法没?

一般情况,标签设置一天只能成功设置一次,如果需要一天多次,可以提需求添加的。

11、后一个标签会顶替掉前一个标签么?还是以前打的标签和后面的标签同时存在?

标签设置是全量覆盖的,后者全部替换前者。

12、打标签的时效性,执行打标签操作,时间过了好久才有这样的标签用户?

开通权限后,最高设置的记录是一天100次。这个权限目前只有个推技术支持那边可以设置。

二、 Device token(设备�令牌)概念:
deviceToken

这周在学习苹果的消息推送(Apple Push Notification),官方画的流程图很清晰,但是对里面的一个概念 device token 却语焉不详。
读完冗长的文档,唯一有用的却是一个注意事项:
An application should register [with APN servers] every time it launches and give its provider the current token.每次应用被打开时,开发者都要重新收集当前设备的 device token,因为它可能变了哦。
stackoverflow 针对Device token 什么时候会发生变化有个很棒的解答。
在一台设备中, device token 是系统级别的,不同 App 获得的 device token 是相同的。
假如我的手机安装了 Angry Bird 和 Evernote ,这两个应用获得 device token 一模一样。
device token 并不会因为单个 app 的更新而发生改变。
假如我的 iPhone 升级了最新版的愤怒的小鸟,这并不会导致我 device token 的改变。
假如我的 iPhone 从 backup 中恢复数据,device token 不会发生变化。
用户抹除 iPhone 的数据时,意味着要与这台手机撇清关系,比如出售或者送人。此时为了保护隐私,device token 会改变。
在需要发送push时,我们的服务端就会取出要发送的设备的device token,然后以如下方式组成特定结构字符串,然后发送至APNs

toAPNs.png

参考:
1、http://www.cnphp6.com/archives/50193
2、http://www.jianshu.com/p/c46b60f06880
3、http://www.jianshu.com/p/803bfaae989e
4、http://mednoter.com/device-token.html
5、http://www.360doc.com/content/12/1116/09/10941785_248142762.shtml

相关文章

  • iOS集成个推小结

    一、以下为我集成时的问题与解决方案: 1、iOS通知,在官网后台怎么推送,不能单独推送通知? iOS只能透传消息,...

  • 个推小结

    iOS集成个推小结 2016年07月18日 20:05:09 跃然 阅读数:3448 标签: ios 更多 个人分...

  • IOS集成个推总结

    IOS集成个推总结 标签(空格分隔): IOS IOS集成个推总结 集成注意点 1 去个推后台申请app的应用 如...

  • iOS 个推集成 <笔记篇>

    参考个推集成方式① iOS集成视频[https://docs.getui.com/getui/mobile/ios...

  • iOS 【视频直播一】安装环境

    摘抄:快速集成iOS基于RTMP的视频推流摘抄:iOS中集成ijkplayer视频直播框架 Mac搭建nginx+...

  • Mac搭建nginx+rtmp服务器

    快速集成iOS基于RTMP的视频推流 - 简书

  • flutter七牛直播推流插件 Readme

    七牛直播推流插件 Android is OK IOS is developing 如何使用 Android集成在你...

  • iOS开发个推集成中的注意点(手动集成)

    一、个推的集成 1.个推的集成可以参考个推的集成文档。 2.初步集成的代码如下: APPDelegate.h AP...

  • 极光推送小结 - iOS

    此次即友盟分享小结(友盟分享小结 - iOS)之后对推送也进行了一版优化.此次分享内容依然基于已经成功集成 SDK...

  • 个推集成

    集成过程就不多说了,参照官方文档。(消息推送必须用真机测试)官方地址:个推官网 集成大致过程: 1.登陆注册 2....

网友评论

  • dedenc:楼主,程序在后台如果透传几条消息点击其中一条通知进入前台,所有的透传消息都会接收到,你是怎么处理的? 我现在相当于点一条所有的消息都执行了
    _浅墨_:@dedenc 点击通知栏进去,可以在苹果的代理方法中进行代码控制,个推的那个代理方法每次都会执行,这个要代码逻辑判断过滤一下的
    dedenc:@_浅墨_ 你这个并不是用来区分的,offline只是判断当前时候离线的,现在就是从点击通知栏的消息进入app,比如说收到了10条个推信息,我点击其中的某一条 所有的个推消息都会进入到这个方法里进行逻辑处理 而且通知栏和角标都会被清零
    _浅墨_:application.applicationState == UIApplicationStateActive 以及 - (void)GeTuiSdkDidReceivePayloadData:(NSData *)payloadData andTaskId:(NSString *)taskId andMsgId:(NSString *)msgId andOffLine:(BOOL)offLine fromGtAppId:(NSString *)appId 中的 offLine 结合使用,试试
  • __weak:楼主你好,我现在集成成功了,并且在测试devicetoken那里也能收到推送消息,可是自己去透传那里测试就是不行啊,我想问问为什么这样呢
    _浅墨_:@__weak 有些 bug 就是这样坑 有些也可能是个推 sdk 的问题
    __weak:@_浅墨_ 无缘无故可以了,我也是醉了。谢谢楼主
    _浅墨_:@__weak 看看配置是否正确,appKey、证书等是否对应,还有 Xcode 中要勾选打开推送功能
  • MakeThatChange:你好,用户不开启通知,也可以收到透传数据吗?
    _浅墨_:@MakeThatChange :relaxed:客气啊
    MakeThatChange:@_浅墨_ 嗯嗯 感谢回复~:smile:
    _浅墨_:@MakeThatChange 可以的,透传消息走的是个推服务器
  • 点亮橘子树:接收到推送消息 时间处理在哪里处理呢
  • missunderstand:在个推方面,关于iOS的APN博主有什么经验可以简单介绍下吗
    _浅墨_:@missunderstand 这个可以看看我的另一篇个推总结,然后最好的还是看官方文档,:wink:
  • 不可以被嘲笑的大树:如果用户在后台收到推送点击提示栏进来 首先经过didReceiveRemoteNotification 我们也可以在这个方法里面 拿到推送的内容 可以直接处理 也可以说在GeTuiSdkDidReceivePayloadData 方法 通过offline判断是否是离线消息 然后拿到推送的内容处理是么
  • 不可以被嘲笑的大树:想请问楼主下 如果App在后台收到推送 点击通知栏 或者点击App图标进入应用 都会经过GeTuiSdkDidReceivePayloadData这个代理方法么
    _浅墨_:@不可以被嘲笑的大树 应该可以的,你可以弹框测试一下
  • 丶余晖:楼主,我这边集成个推,现在碰到了一点问题,如果方便想请教下你,我这已经集成成功了,可以收到消息,主要是我不清楚用户在前台或者后台收到通知,应该怎么来处理,产品这边也不是很懂,所以想借鉴下你的做法,感谢,微信kaeersnow
  • b607879e9326:我今天试着导入了一下, 但是总是显示 GeTuiSdk.h not found 怎么回事
  • b607879e9326:我现在想用getui, 但是不知道怎么用, 不知道楼主是否可以帮忙
    _浅墨_:@b607879e9326 官方文档是最好的学习地方,有问题了可以一起讨论...
  • 4990145ebbf7:楼主:我现在用的额个推,在收到消息后做处理的时候,会有一个BUG,请教一下楼主,微信号:baihei2011,已申请加楼主微信了。
  • Ths:使用别名进行单点推送,你说的clientId是什么意思啊
    _浅墨_:@路小凤_max 好的,多谢提醒
    Leo_L:@子充 用cid 注册成别名 只适合账号只能单点登录的情况。账号只能在一台设备上登录。
    _浅墨_:@Ths 个推那边注册的唯一id
  • hu9134:学习了,最近在打算使用个推
    _浅墨_:@hu9134 可以先了解一下,有问题相互讨论呗

本文标题:iOS集成个推小结

本文链接:https://www.haomeiwen.com/subject/haqzlttx.html