您的位置:首页 > 移动开发 > IOS开发

iOS -- 处理推送消息

2016-03-17 17:36 489 查看
简介

很多应用都会实现推送功能,我们可以集成第三方框架实现推送功能,比如:

JPush推送:https://www.jpush.cn

个推:http://www.getui.com

下面来说说收到推送消息的逻辑处理

收到推送消息有三种情况:

1、应用未启动(默认显示在通知栏,或者锁屏时显示在锁屏页面)

2、应用在后台挂起(默认显示在通知栏,或者锁屏时显示在锁屏页面)

3、应用在前台(默认不显示)

点击推送消息有两种情况:

1、应用未启动 -> 启动

这个时候如论是点击推送消息打开应用还是点击icon打开应用都会调用以下方法:

- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions{

}


通过launchOptions判断应用是点击推送消息打开应用还是点击icon打开应用,点击推送消息启动应用会把推送的消息userInfo通过launchOptions参数传递过来。

推送是远程推送:

if (launchOptions) {
NSDictionary *userInfo = [launchOptions objectForKey:UIApplicationLaunchOptionsRemoteNotificationKey];
if (userInfo) {
//接收到远程推送进行相应的逻辑处理
}
}


推送是本地推送:

if (launchOptions) {
UILocalNotification *notifi = [launchOptions objectForKey:UIApplicationLaunchOptionsLocalNotificationKey];
if (notifi) {
//处理本地推送消息
}
}


2、应用在后台 -> 应用在前台

应用在后台挂起时点击推送消息和应用在前台时收到推送消息,都会调用以下方法:

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

}


应用在后台挂起时默认是不调用该方法的,如果你需要接收到推送消息还没点击推送就调用该方法,可以让服务器发给APNS时在aps 字典中加入:

aps = {
  content-available = 1;
}

应用有三种状态:未启动、后台挂起、前台;我们可以通过以下方法获取状态:

NSInteger state = [UIApplication sharedApplication].applicationState;
if (state == UIApplicationStateActive) {
//应用在前台
}
else if(state == UIApplicationStateBackground){
//应用在后台
}
else if(state == UIApplicationStateInactive){
//应用从后台->前台
}


PS:

最近负责公司项目的推送功能,要求根据推送消息中的“类型”参数判断具体跳转位置,项目中使用的是“个推”,下面来简单说说个推。

个推中有个透传消息模版,只要应用在前台就会收到所有发过来的透传消息(不做任何显示,显示需要自己定义),即使关闭推送功能也会收到透传消息;接受到该消息会调用以下方法:

- (void)GeTuiSdkDidReceivePayload:(NSString *)payloadId andTaskId:(NSString *)taskId andMessageId:(NSString *)aMsgId andOffLine:(BOOL)offLine fromApplication:(NSString *)appId {

// [4]: 收到个推消息
NSData *payload = [GeTuiSdk retrivePayloadById:payloadId];

/**
*汇报个推自定义事件
*actionId:用户自定义的actionid,int类型,取值90001-90999。
*taskId:下发任务的任务ID。
*msgId: 下发任务的消息ID。
*返回值:BOOL,YES表示该命令已经提交,NO表示该命令未提交成功。注:该结果不代表服务器收到该条命令
**/
[GeTuiSdk sendFeedbackMessage:90001 taskId:taskId msgId:aMsgId];
}


关于本地推送参考文档:

/article/1513762.html
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: