最近写的ionic2项目,需要处理隔天请求某些数据时,会提示非法请求,然后根据后端返回的error,退出登录,并返回到登录页.
然后,步骤就是 调用退出登录的接口,在成功的状态里,接着清除在启动页记录存储用户的信息("userid",token,sid)等信息. 然后设置Login为root跟目录 : this.nav.setRoot(LoginPage);
然后,突然想起来了之前ios写的 登录,退出 功能. 无非不也是这种思路呢.. 然后搜了下,ios退出登录的实现. 一大堆问题,说各种 的都有,. 1. 说什么再次登录成功后 进入的是设置界面(退出按钮所在的页面),
2. 有的说再次进去app的时候,没有显示登录页面,而是进的首页.
其他的还有一大堆............
1. 我们先来分析下第一种 的情况: 退出成功了, 的确也回到登录页了.. 那么你是如何回到登录页的? modal? dismiss? 这新手也很少会犯这样的错误吧? 请你先搜搜push 和 Modal 到底是怎么用的.
2.第二种情况. 明明退出了,为何再次进去app的时候,没有显示登录页面,而是进的首页.
首先,退出跳转的代码是怎么写的?是不是写在退出请求返回成功的代码里? 没有有设置tab select(0)选中第一个角标?, 只有当成功的时候,你再去跳转到登录页啊. 其次是你在登录的时候,是不是做了保存密码,自动登录处理? 如果是的话,那你在退出的时候,是否清除了存储的某些信息或设置? 如果你能把这两点搞清楚,也就能避免第二种情况了.
然后说下比较严谨的退出登录,返回登录页的步骤.
加入这是一个退出登录请求返回的block : outLogin(data){
if(data.success ==1){//即请求成功.
//1.先做清楚数据操作. 清楚你可能存储的 自动登录做保存的信息 或者某些设置
//2.做跳转
UIWindow * window = [[[UIApplication sharedApplication]delegate]window];// 获得根窗口
LoginViewController*loginVC = [[LoginViewController alloc]init];//将登录控制器设置为window的根控制器
UINavigationController * nav = [[UINavigationController alloc]initWithRootViewController: loginVC];
window.rootViewController= nav;
}
}
3.如果想做的更好一点,避免退出APP后再登录时,防止再次跳转设置界面。应当将设置控制器推出到根控制器popToRootViewControllerAnimated
在页面将要消失的代码里面写
- (void)viewWillDisappear:(BOOL)animated {
[superviewWillDisappear:animated];
[self.navigationControllerpopToRootViewControllerAnimated:YES];
NSMutableArray*vcs = [self.navigationController.viewControllers mutableCopy];
[vcs removeAllObjects];
//还有 可以顺便了解下 ViewController的生命周期 看看push 和pop 的时候 哪些Controller是销毁的 哪些是存在的
}
4.顺便再说下保存密码,自动登录时候 token过期的处理
如果设置可自动登录项,那么当你自动登录如果遇到token过期的情况没处理的话,那就是直接进到app (因为默认会请求首页的数据,此时你传递过去的是错误的token), 并且显示非法请求等等(反正就是拿到错误的token,请求数据时, 后台会返给你error)
现在有两种解决方案, 当登录的时候首先会做请求,如果拿到的error等于token错误的,
1. 自动退回到登录页, 让用户从新登录.
2.直接在此处 触发登录请求, 拿到登录成功后返回的最新token. 这时候再进入首页自动请求数据就避免了 非法请求的情况.