多语言展示
当前在线:1523今日阅读:11今日分享:19

个推推送iOS实战教程

消息推送是各类APP为了拉新保活而采取的必要手段之一。考虑到硬件、人员及时间等各类成本、稳定性及并发量等问题,很多APP选择了第三方消息推送服务商。本文为大家介绍iOS APNs实战分享经验,希望对你有帮助。
工具/原料
1

苹果开发许可证书,分为:开发证书(iOS App Development)、生产证书(App Store and Ad Hoc)等,后面我使用的是开发证书进行测试。

2

苹果开发者网站上注册“AppIDs”,我使用的是“com.crazywolf.yewan”,勾选“Push Notifications”。

3

真机(加油,iPhone在等着你),需要添加到开发许可设备中。

4

Provisioning Profiles文件,分:开发时使用(iOS App Development)、生产时使用(App Store、Ad Hoc)等,我在后面使用的是“Development”。

5

苹果APNs推送证书,分:开发环境证书(Development)、生产环境证书(Production)等,同样,也是使用“Development”,注意使用个推平台APNs推送需上传该推送证书,这里我将导出的开发环境证书提交个推平台,关于证书生产和导出可以查看个推APNs配置技术文档(http://docs.getui.com/mobile/ios/apns/)。

6

Xcode8.2(不同版本在配置时有点不同),最低支持版本iOS 8.0。

一、注册APNs、获取DeviceToken
1

创建新项目或修改老项目,配置项目

2

注册APNs,获取DeviceToken

3

使用个推的测试一下,测试DeviceToken是不是很简单,这样就可以获取到APNs推送消息了,有没有一种成功感,不过我开始获取DeviceToken时,一直报(“Error Domain=NSCocoaErrorDomain Code=3000'未找到应用程序的“aps-environment”的授权字符串' UserInfo={NSLocalizedDescription=未找到应用程序的“aps-environment”的授权字符串}”)错误,网上说是证书没配置好,我重新配置了多次证书还是不行,后来问了个推的技术支持才知道Xcode8以上版本需要打开“TARGETS -Capabilities - Push Notifications”,个推的集成文档中也有写,自己太粗心了。

4

APNs环境问题注意保持推送APNs环境和你的App推送环境一致,因为经常有人会把证书环境搞错,导致推送收不到。1)直接使用Xcode直接运行到手机上,可以根据“TARGETS -> General-> Signing”中“Provisioning Profile”和“Signing Certificate”来确认。例如下图:

5

分享一下,我在给“Provisioning Profile”文件命名时有个习惯,以“Dev: ”(开发环境)、“In House: ”(企业包环境)、“XC Ad Hoc: ”(分发包环境)、“XC: ”(App Store),其中后面三个都是生产环境。

6

打包成ipa包安装到iPhone上,可能会忘记打包时的配置或者是其他人发你的包,是不是就不能知道APNs的环境了?很早之前我的方法是获取App的DeviceToken,使用开发和生产环境APNs证书都推送一下,看看是哪个能推送到。后来发现了还有其他方法的,那就是解析ipa包:1)先解压ipa包,找到.app文件,显示包内容2)找到.mobileprovision文件,使用“Atom”打开.mobileprovision文件3)查找“aps-environment”,查看“aps-environment”这个key值对应value,“development”表示开发环境,“production”表示生产环境。如下图:

二、正式推送APNs,推送我们需要的信息
1

集成个推SDK怎么配置个推,可以去看“http://docs.getui.com/mobile/ios/xcode/”,配置成功后运行获取个推的“clientId”。

2

使用个推网站上的“透传消息”下发这样就可以推送自定义消息内容到iPhone上了,到这里APNs的功能已经全部完成了,后面就要看看具体需求了,将个推的服务端集成部分发给你们服务端开发人员,让他“码”起来了,如果有问题,让他们联系个推的技术支持,2333。

3

APNs消息统计个推最新版本1.5.3 iOS SDK添加了“iOS 10 APNs展示统计”功能,该功能使用到了iOS10新特性需要添加NotificationService扩展模块,能准确统计到iOS10以上APNs展示信息,这个功能太爽了,APNs展示数据无法统计是多少开发者及运营的痛啊,相信有了这个功能能更好的跟踪APNs推送到达情况。具体集成步骤可以查看“http://docs.getui.com/mobile/ios/xcode/#6-ios-10-apns”。推送成功后可以在个推后台进行查看推送情况,如图:个推渠道下发还是区分蛮清晰的,个推成功下发为通过个推通道进行下发,APNs成功下发模块为离线后,走APNs通道下发,其中上面说的展示统计数据就是APNs模块中的展示数了。用户量有点小,别介意哈zZZ。

4

回调方法区别APNs的消息在App不同状态、APNs消息内容、通知操作不同、iOS系统版本不同,回调方法也不同,下面这张图片是上次咨询个推时,个推的技术人员发我的,可以参考看看,注意使用时要测试一下,防止苹果系统又变化了:个推的透传消息可以通过方法(“GeTuiSdkDidReceivePayloadData: andTaskId: andMsgId: andOffLine:fromGtAppId: ”)回调获取,因为苹果的APNs推送不保证是否到达和到达时间,所以就可能会丢失,使用个推的透传方法相对APNs更能保证消息的到达率。说到这里不得不说一下个推的推送机制了,在我们服务端给个推服务器推送消息时,个推服务器会检查推送对象是否在线(应该是根据个推SDK和个推服务器心跳包和网络连接判断的,超过一定时间没有收到心跳包就是“不在线”,不过这种做法可能会出现假在线情况,就是忽然断网,在服务器下次检测心跳包的期间,服务器会认为对象在线):1)对象在线:下发个推的透传消息,不发送APNs推送消息。2)对象离线:下发个推的透传消息,发送APNs推送消息。从上面可以看得出,个推的透传消息是每次都下发的,这样也保证的个推的消息到达率,不过这种做法会出现消息重复,例如是收到消息弹框提醒用户操作,个推透传消息和APNs推送消息都收到了,处理不好的话会提醒用户二次一样的消息。这里比较好的是个推在透传消息方法中提供了“offLine”字段,这个值是“YES”时,表示这是一条离线消息,在下发个推透传消息时,也发送了APNs推送消息,在处理消息时可以忽略,如果消息的重要性不是很高,可以这么做,因为在忽略个推的透传消息后APNs消息也没有收到,就导致该条消息丢失。另外一种处理方式:参照网上的一些解决方法,我建立一个配置表,处理过的数据在表中标注,防止APNs和个推的透传方法消息重复操作。

5

个推透传消息注意点下面三张图,第一张是个推网站下发透传消息时的界面,第二张是个推透传消息回调方法。需要特别注意的是第一张图中最下面的“payload”和个推透传方法中“payloadData”,这二个中不是同一个概念。“payload”是个推自定义字段,添加在APNs的消息内容中,不是苹果原生字段,会通过APNs推送消息一并下发到iPhone客户端,结构如上图中代码块展示,这个字段一般是在APNs消息中添加附带消息,例如附带一个酒吧网站url,在收到通知消息是,发现是url,App直接打开这个网址。“payloadData”是该条透传消息内容,对应图上的“*消息内容”,这个字段不会通过APNs推送到iPhone客户端,是通过个推服务器直接下发给个推SDK的。当然你也可以将“*消息内容”和“payload”设置成一样的,这个就看你们的具体使用情况来定了。再说说第一张中“*拆分Android和iOS推送任务”,选择“是”的话,会拆分Android和iOS推送任务后,将生成两个taskid,分别对android和ios推送数据进行统计和展示,方便之后查询推送数据统计。最后一个比较实用的就是个推的“高级通知”,如第三张图,将APNs推送中的字段都列举出来了,不要开发者特意记APNs中有哪些字段,方便一些对APNs还不是很熟悉的初学者使用,当然不包括我了,哈哈哈哈。

6

发布到AppStore注意点App发布到AppStore时,需要更换APNs证书或者更换App中个推AppId,因为个推的网站中只能上传一个证书,开发时上传的都是开发APNs证书,当开发测试完成后,准备发布时,App需要生产环境的APNs证书,这时有二种方案可以使用:1)创建二套个推AppId:这种方案是在个推网站中添加二个应用,一个用于开发、一个用于发布,在开发测试期间使用开发的个推AppId,在发布时使用发布的个推AppId,这种方案需要注意发布时切换AppId,忘记换就GG,第一次发布还好,两个个推AppId的作用互换一下就可以了,如果是更新发布,那只能重新提交苹果审核了。2)更换APNs证书:这种方案是在发布时重新上传生产APNs证书,注意个推的证书更换后需要10分钟左右生效,这种方案需要注意在之后版本更新开发时,需要申请新的个推AppId,不然会影响在线的客户。我使用的是第一种方案,使用二套个推AppId,个推的文档中也是推荐使用第一种方案。

三:公司服务器自己推送和使用个推推送的流程差异
1

公司服务器自己推送(简称:自己推送)流程1)注册APNs,获取DeviceToken2)将DeviceToken和用户ID绑定,保存服务器3)推送时,根据用户ID获取到DeviceToken,将消息内容、DeviceToken和APNs推送证书发送给苹果服务器

2

使用个推推送流程1)注册APNs,获取DeviceToken2)集成个推SDK,获取ClientId,绑定ClientId和DeviceToken3)将ClientId和用户ID绑定,保存服务器4)推送时,根据用户ID获取到ClientId,将消息内容和ClientId发送给个推服务器

四:自己推送和第三方对比
1

成本:自己推送需要专人进行开发,并且需要一定数量的服务器和带宽支持,在开发完成后的使用过程中还需要有专人进行维护。使用第三方推送,只需要集成SDK就可以实现功能,不仅减小了开发成本与维护成本,甚至在推送稳定性上第三方也会比自己做的推送更好一些。

2

精准推送:可以将针对内容及标签等信息进行精准推送,比如将杭州的新闻推送给杭州用户,自己推送需要额外开发,而第三方大部分已经支持这样的功能。

3

推送统计:自己推送还是需要额外开发该功能,而第三方基本都必备该功能,相对来说就我现在使用的个推统计效果还是令人满意的,区分在线下发和APNs下发统计功能,支持通知的展示统计和点击统计,可以知道真实的下发量,下发后有多少被展示了,有多少被点击了。

4

可控性:使用第三方推送可控性太低,想想,如果第三方推送厂商宕机、或者被黑客攻击了,你服务没法推送了,需要等待第三方厂商响应,或者第三方厂商出问题了,也会影响你的推送。所以那些痛的经验告诉我们要选择家专业做推送,比如个推,至少人家也是百亿级用户量,服务器挂了怼他去,哈哈。

5

总结一下:自己推送成本高、服务相对更可控,使用第三方推送成本低、功能更多。特别大,对成本不在乎又要求服务可把控,可以自己搭建推送服务,,使用第三方厂商更加合适,没有统一答案,要根据自身产品特点、公司情况不断权衡和调整。

五:使用个推后的感受
1

在开发测试时,更换了推送证书,证书更换后需要10分钟左右生效,测试时感觉好麻烦,不能立即生效么。

2

推送时,可以角标自动增加,产品的需求,作为一个开发人员不知道有什么好,不过产品这样要求,只能做了,还好个推支持。

3

可以统计通知的展示率和点击率,运营同学可以在推送活动通知后,知道用户对什么样的活动比较感兴趣,更方便他们运营。

4

可以对指定人群推送,例如我们活动在上海,可以指定给上海用户大力推送。这个比较好,不用全部用户都发送,保证不相关的用户不被打扰。

5

个推的透传方法可以保证数据的到达,因为苹果的APNs推送不保证是否到达和到达时间,所以就可能会丢失,使用个推的透传方法可以保证能收到消息。

6

在发送透传消息时,“iOS高级通知”中“代码块”功能比较赞,我个人超喜欢,可以提前预览客户端收到APNs通知消息的数据格式。 日记本

推荐信息