IOS APNs 极光推送
广播推送:
一般的广播推送通过看文档就可以集成得到,并不难(服务端的暂时不会)
极光推送,在程序前台的时候可以收到消息,触发通知方法,默认通知不会在通知栏栏显示,在API里面可以设置.(实际上是转化成本地通知)
/*!
* @abstract 前台展示本地推送
*
* @param notification 本地推送对象
* @param notificationKey 需要前台显示的本地推送通知的标示符
*
* @discussion 默认App在前台运行时不会进行弹窗,在程序接收通知调用此接口可实现指定的推送弹窗。
*/
+ (void)showLocalNotificationAtFront:(UILocalNotification *)notification identifierKey:(NSString *)notificationKey;
这个时候,我们可以通过收到的消息再做逻辑判断可以自定义想要跳转的页面
特定推送:
首先:想要理解特定推送需要了解一下 :
(标签与别名的功能说明)
http://docs.jiguang.cn/client/ios_api/#api-ios
(Alias (别名) 和 registrationID ( 注册ID) 的区别 )
http://blog.jiguang.cn/registrationid_pusn_launch/
懒得看的直接看我的总结吧(推荐看官方介绍)
registrationID:是对设备的唯一标识 使用JPush SDK集成注册的ID
Alias :别名,可以为用户设置别名,一般也是唯一的(极光允许多个设备绑定一个别名),一般我们使用 用户名ID
tag :标签 ,用来贴标签,分群的( eg: 汕头 ,帅哥 , 90后 ,180cm )
//监听极光的通知
extern NSString \*const kJPFNetworkDidSetupNotification; // 建立连接
extern NSString \*const kJPFNetworkDidCloseNotification; // 关闭连接
extern NSString \*const kJPFNetworkDidRegisterNotification; // 注册成功
extern NSString \*const kJPFNetworkDidLoginNotification; // 登录成功
extern NSString \*const
kJPFNetworkDidReceiveMessageNotification; // 收到消息(非APNS)
extern NSString \*const kJPFServiceErrorNotification; // 错误提示
在 kJPFNetworkDidLoginNotification 通知里获取到 RegistrationID
[JPUSHService registrationID];
把RegistrationID上传到服务器,可以用于更复杂的逻辑判断。(eg:统计有多少个安装了这个应用的用户)
+ (void)setTags:(NSSet *)tags alias:(NSString *)alias
fetchCompletionHandle:(void (^)(int iResCode, NSSet *iTags, NSString*iAlias))completionHandler;
这个方法设置tags 标签组(注意:NSSet<NSString> 一定items一定是字符串) 设置 iAlias (别名)
与RegistrationID进行绑定。
这里需要注意的是需要再block回调里面判断 iResCode == 0 (0表示绑定成功),然后再做其他的操作。
注意循环引用
点对点推送:
分群推送:
点对点推送只需要 在某一个 时机、应用场景 传参数给服务器,让服务器去发送推送通知就行了,客户端的只需要设置好这些 参数(标签,别名......)和记录就行了,分群推送也是一样的,可以在JPush的官网后台进行测试
当然,你需要处理一下角标的问题,也可以根据需求直接忽略也行。
一些需要注意的问题:
1.打印调试日志:查询 Jpush的API 可以知道 ,默认是开启 info 级别的(必要信息)信息打印
(JMessage iOS 的日志系统参考 Android 设计了级别。从低到高是: Verbose, Debug, Info, Warning, Error.)
调用 + (void)setDebugMode 开启全套打印日志
关闭 + (void)setLogOFF 极光推荐在发布的版本中不要打印这些调试信息
API:
/*!
* @abstract 打开日志级别到 Debug
*
* @discussion JMessage iOS 的日志系统参考 Android 设计了级别.
* 从低到高是: Verbose, Debug, Info, Warning, Error.
* 对日志级别的进一步理解, 请参考 Android 相关的说明.
*
* SDK 默认开启的日志级别为: Info. 只显示必要的信息, 不打印调试日志.
*
* 调用本接口可打开日志级别为: Debug, 打印调试日志.
*/
+ (void)setDebugMode;
/*!
* @abstract 关闭日志
*
* @discussion 关于日志级别的说明, 参考 [JPUSHService setDebugMode]
*
* 虽说是关闭日志, 但还是会打印 Warning, Error 日志. 这二种日志级别, 在程序运行正常时, 不应有打印输出.
*
* 建议在发布的版本里, 调用此接口, 关闭掉日志打印.
*/
+ (void)setLogOFF;
一些需要知道了解地方:
极光还集成的统计的功能,看来大数据时代,个个都准备插一脚,这样也是方便我们统计
功能有:统计你在当前页面的停留时间,可以分析用户对那个页面比较感兴趣,传的时页面的名字(自己想传什么标志就传什么标志),具体查一下API。
还是贴出来吧
///----------------------------------------------------
/// @name Stats 统计功能
///----------------------------------------------------
/*!
* @abstract 开始记录页面停留
*
* @param pageName 页面名称
*/
+ (void)startLogPageView:(NSString *)pageName;
/*!
* @abstract 停止记录页面停留
*
* @param pageName 页面
*/
+ (void)stopLogPageView:(NSString *)pageName;
/*!
* @abstract 直接上报在页面的停留时工
*
* @param pageName 页面
* @param seconds 停留的秒数
*/
+ (void)beginLogPageView:(NSString *)pageName duration:(int)seconds;
/*!
* @abstract 开启Crash日志收集
*
* @discussion 默认是关闭状态.
*/
+ (void)crashLogON;
/*!
* @abstract 地理位置上报
*
* @param latitude 纬度.
* @param longitude 经度.
*
*/
+ (void)setLatitude:(double)latitude longitude:(double)longitude;
/*!
* @abstract 地理位置上报
*
* @param location 直接传递 CLLocation
* 型的地理信息 *
* @discussion 需要链接 CoreLocation.framework 并且 #import
*/
+ (void)setLocation:(CLLocation *)location;