刚进入后台的时候消息处理时候我用了本地推送!可以看我前边写的博客,怎么处理刚进入后台接收推送的案例,链接

/**

注释:打开推送的三种方式:-peter

1、apns的时候,结束进程退出后台:启动的时候可在 didFinishLaunchingWithOptions的launchOptions中处理;

获取字典 launchOptions 中的 UIApplicationLaunchOptionsRemoteNotificationKey的key

NSDictionary *optionsRemoteNotificationKey = [launchOptions dictionaryValueForKey:@"UIApplicationLaunchOptionsRemoteNotificationKey"];

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

{

/**二次启动获得推送点击信息,本地储存二次启动的内容 仿qq点击推送栏启动 by peter***/

NSDictionary *optionsRemoteNotificationKey = [launchOptions dictionaryValueForKey:@"UIApplicationLaunchOptionsRemoteNotificationKey"];

[[NSUserDefaults standardUserDefaults] setObject:optionsRemoteNotificationKey forKey:kSavePushMessage];

/**为了验证第一次启动的时候不能截获启动信息,加啊alert**/

/**

NSString * str = [NSString stringWithFormat:@"%@",launchOptions];

dispatch_after(dispatch_time(DISPATCH_TIME_NOW, (int64_t)(5 * NSEC_PER_SEC)), dispatch_get_main_queue(), ^{

UIAlertView *art = [[UIAlertView alloc]initWithTitle:nil message:str delegate:self cancelButtonTitle:@"取消" otherButtonTitles: nil];

[art show];

});

**/

return YES;

}

2、apns的时候,结束进程未退出后台:启动的时候可在 didReceiveRemoteNotification的userInfo中处理;

- (void)application:(UIApplication *)application didReceiveRemoteNotification:(NSDictionary *)userInfo

{

NSString *  appData = [userInfo stringValueForKey:@"appData"];

NSData *jsonData = [appData dataUsingEncoding:NSUTF8StringEncoding];

NSError *err;

NSDictionary *dic = [NSJSONSerialization JSONObjectWithData:jsonData

options:NSJSONReadingMutableContainers

error:&err];

if(err)

{

NSLog(@"json解析失败:%@",err);

}else{

NSString * positionIdString = [NSString stringWithFormat:@"%@",[dic numberValueForKey:@"positionId"]] ;

if ([dic numberValueForKey:@"positionId"] !=0) {

[[NSNotificationCenter defaultCenter] postNotificationName:kString_DispantData object:positionIdString];

}

}

}

3、本地推送,未结束进程未退出后台(此方达为了解决消息刚进入后台时候没有通知的情况):启动的时候可在 didReceiveLocalNotification的notification中处理;

- (void)application:(UIApplication *)application didReceiveLocalNotification:(UILocalNotification *)notification{

NSDictionary *dic = notification.userInfo;

NSString * positionIdString = [dic stringValueForKey:@"positionId"];

if (![positionIdString isEqualToString:@""]) {

[[NSNotificationCenter defaultCenter] postNotificationName:kString_DispantData object:positionIdString];

}

}

**/

二、处理页面跳转功能

说明:由于情况1都代表app已经结束需要重新启动,只能做本地存储,然后到tabbar页面的时候取出该存储值的对应id然后进行跳转。情况2、3  ,App的tabbar页面已经存在可以注册一个通知在2、3的情况时候发送通知!

1、存储调转

在tabbar的viewDidAppear方法

- (void)viewDidAppear:(BOOL)animated

{

[super viewDidAppear:animated];

NSDictionary *optionsRemoteNotificationKey = [[NSUserDefaults standardUserDefaults] objectForKey:kSavePushMessage];

NSString *appDataString = [optionsRemoteNotificationKey stringValueForKey:@"appData"];

if (appDataString&&![appDataString isEqualToString:@""]) {

[[NSUserDefaults standardUserDefaults] setObject:nil forKey:kSavePushMessage];

}

}

2、通知跳转

注册监听tabbar的viewDidLoad方法里边

- (void)viewDidLoad

{

[[NSNotificationCenter defaultCenter] addObserver:self selector:@selector(pushDispanchPositionDetail:) name:kString_DispantData object:nil];

}

方法接收

#pragma mark observer Notification

-(void)pushDispanchPositionDetail:(NSNotification *)notify

{

if (notify.object&&![notify.object isEqualToString:@""]) {

[self pushData:notify.object];

}

}

- (void)pushData:(NSString *)positionId{

[self setSelectedIndex:MainTabBarIndex_User];

RootNavigationController* selNavi = [self.viewControllers objectAtIndex:MainTabBarIndex_User];

HHPositionDetailC *vc = [[HHPositionDetailC alloc] init];

vc.positionId = [positionId longLongValue];

dispatch_after(dispatch_time(DISPATCH_TIME_NOW, (int64_t)(0.25 * NSEC_PER_SEC)), dispatch_get_main_queue(), ^{

selNavi.toolbar.hidden = YES;

[selNavi pushViewController:vc animated:YES];

HDMyPositionViewController *myPositionVC = [[HDMyPositionViewController alloc]init];

NSMutableArray *mutArray = [NSMutableArray arrayWithArray:selNavi.viewControllers];

[mutArray insertObject:myPositionVC atIndex:1];

selNavi.viewControllers = [mutArray copy];

});

}

详细解释跳转代码

[self setSelectedIndex:MainTabBarIndex_User];

RootNavigationController* selNavi = [self.viewControllers objectAtIndex:MainTabBarIndex_User];

HHPositionDetailC *vc = [[HHPositionDetailC alloc] init];

vc.positionId = [positionId longLongValue];

dispatch_after(dispatch_time(DISPATCH_TIME_NOW, (int64_t)(0.25 * NSEC_PER_SEC)), dispatch_get_main_queue(), ^{

selNavi.toolbar.hidden = YES;

[selNavi pushViewController:vc animated:YES];

HDMyPositionViewController *myPositionVC = [[HDMyPositionViewController alloc]init];

NSMutableArray *mutArray = [NSMutableArray arrayWithArray:selNavi.viewControllers];

[mutArray insertObject:myPositionVC atIndex:1];

selNavi.viewControllers = [mutArray copy];

});

1、找到所进入的viewController的根导航Navigation;然后进行选中(self代表tabbar)  [self setSelectedIndex:MainTabBarIndex_User];

2、然后延迟调转,由于初始化tababr的原因不延迟跳转会出现调转不进去的情况;所以做延迟跳转处理。

[selNavi pushViewController:vc animated:YES];

3、找到当前的viewControllers数组,创建需要返回的二级页面加入栈中!

这样就能点推送进入C,返回B,在返回所需要的tabbar的某个界面。

iOS刚进入后台接受推送、打开推送调转到相应的界面的更多相关文章

  1. IM-iOS退出后台接受消息,app退出后台能接收到推送

    App被失活状态的时候可以走苹果的APNS:但是在活跃的时候却接受不到推送! 那就用到本地推送:UILocalNotification 消息神器. 处理不好可能会有很多本地推送到来,那么问题来了要在什 ...

  2. android系统和ios系统是如何实现推送的,ios为什么没有后台推送

    ios系统为什么没有后台推送? iOS 为了真正地为用户体验负责,不允许应用在后台活动.有了这个限制,但是对于终端设备,应用又是有必要“通知”到达用户的,随时与用户主动沟通起来的(典型的如聊天应用). ...

  3. Android P正式版即将到来:后台应用保活、消息推送的真正噩梦

    1.前言 对于广大Android开发者来说,Android O(即Android 8.0)还没玩热,Andriod P(即Andriod 9.0)又要来了.   下图上谷歌官方公布的Android P ...

  4. iOS 之消息推送(个推)---个人小结

    前言:自从上个星期开始整这个推送,弄了差不多一个星期,今天终于给整好了,因此现在来记录这段"奇妙"的旅程. 我们公司使用的消息推送是用的第三方--个推,这里不得不说一下,个推的技术 ...

  5. 最新的极光推送服务器端代码(java服务器后台向手机端自定义推送消息)

    一共两个类 一个Jdpush  一个JpushClientUtil 代码如下   注解都写的很清楚 package com.sm.common.ajpush; import org.slf4j.Log ...

  6. Android实现点击通知栏后,先启动应用再打开目标Activity ,极光推送等推送的也可以参考一下(转)

    我因为项目中集成了极光推送,推送的通知栏点开需要确定进入哪个界面就参考了这边文章,感谢作者的无私. 标签: 情况简述 在开发Android app的过程中,遇到这样一个需求:app中启动一个Servi ...

  7. IOS中程序如何进行推送消息(本地推送,远程推送)2(上)

    未看过本地推送的,可以提前看一下本地推送. http://www.cnblogs.com/wolfhous/p/5135711.html =============================== ...

  8. Android 后台应用保活、消息推送

    3.针对以往Android版本的各种保活技术回顾 Android P之前为了搞定客户的投诉:“为什么微信能收到消息而你们的IM却不能?”,为了解决这个“痛点”,广大的Android开发者们只能让各种黑 ...

  9. iOS和Android后台机制对比

    转自:http://blog.csdn.net/zsch591488385/article/details/27232881 一.iOS的“伪后台”程序 首先,先了解一下ios 中所谓的「后台进程」到 ...

随机推荐

  1. 接口测试执行工具Postman:模拟请求、用例执行、断言、批量运行用例、简单持续集成

    一.接口测试-postman-模拟HTTP Requests 二.接口测试-postman-权限Authorization 三.接口测试-postman-断言Writting Test 四.接口测试- ...

  2. 安装apache报没有找到VCRUNTIME40.dll错误

    解决办法 在Windows下运行最新版的Apache和php7都需要Visual C++Redistributable 2015,而之前的版本不需要那么高的,这个组件是运行Visual Studio ...

  3. java 集合类Array、List、Map区别和优缺点

    Java集合类主要分为以下三类: 第一类:Array.Arrays 第二类:Collection :List.Set第三类:Map :HashMap.HashTable 一.Array , Array ...

  4. myeclipse8.5打包jar并引入第三方jar包

    用myeclipse自带的export工具,无法引入被引用的第三方的jar包,有两种方式: (1)直接export出jar包,解压jar包(第三方的jar包太多,太麻烦) 在创建好的JAR文件里找到M ...

  5. linux 运维,代理,acl控制访问

    运维概述:运行 & 维护,Operation & MaintanceIT运维.业务运维.日常管理运维采用相关的方法.手段.技术.制度.流程和文档等,对IT运行环境.IT业务系统和IT运 ...

  6. Vue项目搭建及原理一

    一. Vue简介 Vue简介 Vue是近两年来比较火的一个前端框架(渐进式框架),与reactjs和angularjs三国鼎立,根据不完全统计,包括饿了么.稀土掘金.苏宁易购.美团.天猫.荔枝FM.房 ...

  7. MxNet+R︱用R语言实现深度学习(单CPU/API接口,一)

    MxNet有了亚马逊站台之后,声势大涨,加之接口多样化,又支持R语言所以一定要学一下.而且作为R语言的fans,为啥咱们R语言就不能上深度学习嘞~ -------------------------- ...

  8. TI Davinci DM6446开发攻略——根文件系统的裁剪和移植

    一.补充文件系统知识 Linux根文件系统是存放tool软件.lib文件.script(脚本).配置文件.其他特殊文件.自己开发的应用程序的地方.嵌入式linux的根文件系统rootfs就像windo ...

  9. R语言︱SNA-社会关系网络 R语言实现专题(基础篇)(一)

    每每以为攀得众山小,可.每每又切实来到起点,大牛们,缓缓脚步来俺笔记葩分享一下吧,please~ --------------------------- 笔者寄语:这里所有的应用代码都来自与igrap ...

  10. FusionCharts封装-Data

    DataSet.java: /** * @Title:DataSet.java * @Package:com.fusionchart.model * @Description:FusionCharts ...