iOS -- 处理推送消息

简介服务器

不少应用都会实现推送功能,咱们能够集成第三方框架实现推送功能,好比:app

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

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

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

收到推送消息有三种状况:spa

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

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

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

点击推送消息有两种状况:事件

一、应用未启动 -> 启动

这个时候如论是点击推送消息打开应用仍是点击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) {
            //处理本地推送消息
        }
    }

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

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

- (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];
}

 关于本地推送参考文档:

http://blog.csdn.net/woaifen3344/article/details/44302635

相关文章
相关标签/搜索