【iOS】处理推送消息

很多应用都会实现推送功能,我们可以集成第三方框架实现推送功能,比如:
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 {
        //  收到个推消息
        NSData *payload = [GeTuiSdk retrivePayloadById:payloadId];
        /**
        *汇报个推自定义事件
        *actionId:用户自定义的actionid,int类型,取值90001-90999。
        *taskId:下发任务的任务ID。
        *msgId: 下发任务的消息ID。
        *返回值:BOOL,YES表示该命令已经提交,NO表示该命令未提交成功。    注:该结果不代表服务器收到该条命令
        **/
        [GeTuiSdk sendFeedbackMessage:90001 taskId:taskId msgId:aMsgId];
}

关于本地推送参考文档:
http://blog.csdn.net/woaifen3344/article/details/44302635

你可能感兴趣的:(【iOS】处理推送消息)