在用uniapp开发一个项目时,有这样一个需求:用户首次登录后,uniapp自动保存用户名密码,之后不管是再次打开项目(打开项目时登录状态已失效)还是 请求接口(接口返回登录失效)时,都会先自动默认的登录,然后再进行之后的操作。

  比如页面需要调用功能接口1、2,但是必须是登录状态。如下图所示:

  

  根据图中的逻辑流程可以断定共有 登录接口、功能接口1、功能接口2 三个request请求,我们抛开要跳转登录页的情况下,那么打开页面会有两种需要特殊处理的情况:

  1.没有登录状态,程序默认调用已存的用户名和密码去调用登录接口,接口登录成功后再继续调用功能接口1和2。

  2.页面已存在登录状态(比如vuex判断是否登录),但是调用接口1或者2时返回需要登录的状态(可能页面停留时间过久,服务器保存的登录状态已失效),这时需要跳到第一种情况去执行。

  

  根据上述的两种情况,我们常见的解决办法就是

 //页面执行
if(!loginStatus){//页面判断是否登录
login();
}else{
server();
}
//假如server中的catch为接口返回登录失效,需要重新登录
function server(){ server1Promise().then(()=>{
}).catch(()=>{
login();
})
server2Promise().then(()=>{
}).catch(()=>{
login();
})
}
function login(){
loginPromise().then(()=>{
server();
})
}

  这样会有很多问题,比如  无法分开调用接口1、接口2(有时候页面逻辑会需要分开调用); 同时调用接口1和2,都返回需要登录状态时,会重复去请求登录接口,进而重复请求接口1和2。

  那么就需要另一种解决方法能同时解决这个问题! 

  

///  request.js
const request = (data,url) = >{
return new Promise((s,f)=>{
uni.request({//也可以是其他的接口请求
complete(r){
if(r.statusCode == 200)
s(r);
else
f(r);
},
url:url,data:data
})
})
} let isLogin =false;//是否正在登录
let loginStatus = async function () { return true}();//登录结果,默认可以登录
const _req = async (_d,_u)=>{
return new Promise((s,f)=>{
let _let_go = await loginStatus.catch(()=>{return false;});
if(_let_go){
request(_d,_u).then((r)=>{
s(r)//接口返回正常
}).catch(()=>{
//假使catch是调用业务接口返回要登录
autoLogin();//自动登录
let _let_go_n = await loginStatus.catch(()=>{return false;});
if(_let_go_n){
request(_d,_u).then((r)=>{ s(r)}).catch(()=>{ f({status:0,msg:'请登录'}) }) //再次请求,如果还是失败就不再继续
}else{ f({status:0,msg:'请登录'})}
})
}else{
//已经调用了登录接口,还是失败,那么跳转到登录页
f({status:0,msg:'请登录'})
}
});
} //自动登录
const autoLogin = ()=>{
if(isLogin ){return}
var _f = ()=>{
isLogin =true;
return new Promise((s, f) => {
var userinfo= uni.getStorageSync('userinfo');//读取保存的用户名密码
if(userinfo){
request(userinfo,'login').then(()=>{isLogin =false;s(true)}).catch(()=>{isLogin =false;s(false)});
}else{isLogin =false;s(false)} })
}
loginStatus = _f();
} //业务接口
const server1 = (_d)=>{
return _req(_d,'server1')
}
const server2 = (_d)=>{
return _req(_d,'server2')
} //登录接口,登录接口要和autoLogin分开,在login成功后要保存用户名和密码
const login = (_d)=>{ ... }

export default {server1,server2,login } /// page.vue
import request from 'request.js'
...
业务逻辑
...
request.server1().then()
...
业务逻辑
...
request.server2().then()

JS利用async、await处理少见的登录业务逻辑的更多相关文章

  1. [.NET] 利用 async & await 的异步编程

    利用 async & await 的异步编程 [博主]反骨仔 [出处]http://www.cnblogs.com/liqingwen/p/5922573.html  目录 异步编程的简介 异 ...

  2. [.NET] 利用 async & await 进行异步 IO 操作

    利用 async & await 进行异步 IO 操作 [博主]反骨仔 [出处]http://www.cnblogs.com/liqingwen/p/6082673.html  序 上次,博主 ...

  3. 利用 async & await 的异步编程

    走进异步编程的世界 - 开始接触 async/await 利用 async & await 的异步编程 async 的三大返回类型 公司技术需求备忘录

  4. 如何利用动态URL提升SEO及处理业务逻辑

    如果你正在建设一个新网站或者对现有网站重新设计,我们认为应该将网站的 URL 转换为用户友好的 URL,或搜索引擎友好的 URL,这类 URL 也称为语义 URL(Semantic URL).哪些UR ...

  5. JavaScript 利用 async await 实现 sleep 效果

    const sleep = (timeountMS) => new Promise((resolve) => { setTimeout(resolve, timeountMS); }); ...

  6. 理解 js的 async/await

    async 和await 在干什么? async  用于声明一个function是异步的 await用于等待一个异步方法执行完成(其实我理解的是等待的是一个表达式,就是一个结果), 其中  await ...

  7. sso 登录业务逻辑

  8. How Javascript works (Javascript工作原理) (四) 事件循环及异步编程的出现和 5 种更好的 async/await 编程方式

    个人总结: 1.讲解了JS引擎,webAPI与event loop合作的机制. 2.setTimeout是把事件推送给Web API去处理,当时间到了之后才把setTimeout中的事件推入调用栈. ...

  9. promise 进阶 —— async / await 结合 bluebird

    一.背景 1.Node.js 异步控制 在之前写的 callback vs async.js vs promise vs async / await 里,我介绍了 ES6 的 promise 和 ES ...

随机推荐

  1. history API,判断页面是否是在跳转链接后返回

    https://www.cnblogs.com/accordion/p/5699372.html history.replaceState(history.state, null, "htt ...

  2. vs2015 调试 无法启动程序

    应用程序输出在这个目录 E:\learn\3dlesson\lesson1_createwindow\build\Debug 项目属性 解决方案: 把项目设为启动项目.

  3. GAN生成式对抗网络(四)——SRGAN超高分辨率图片重构

    论文pdf 地址:https://arxiv.org/pdf/1609.04802v1.pdf 我的实际效果 清晰度距离我的期待有距离. 颜色上面存在差距. 解决想法 增加一个颜色判别器.将颜色值反馈 ...

  4. git reset 版本回退操作

    1 git回退命令 git reset --hard GIT_HEAD   GIT_HEAD是你具体要回退的分支: 如图:   注:  查询GIT_HEAD可以通过两个命令:git log 获取未删除 ...

  5. [Windows]Visual Studio Code个人配置

    编辑器要添加的 settings.json 打开这个: { ,//编辑字号 "files.autoSave": "afterDelay",//自动保存 &quo ...

  6. 走进JavaWeb技术世界开篇:JavaWeb技术汇总

    微信公众号[Java技术江湖]一位阿里 Java 工程师的技术小站.(关注公众号后回复”Java“即可领取 Java基础.进阶.项目和架构师等免费学习资料,更有数据库.分布式.微服务等热门技术学习视频 ...

  7. Leetcode题目292.Nim游戏(脑筋急转弯)

    题目描述: 你和你的朋友,两个人一起玩 Nim 游戏:桌子上有一堆石头,每次你们轮流拿掉 1 - 3 块石头. 拿掉最后一块石头的人就是获胜者.你作为先手. 你们是聪明人,每一步都是最优解. 编写一个 ...

  8. mysql —复制

    MySQL的扩展 读写分离  复制:每个节点都有相同的数据集 向外扩展 二进制日志 单向 复制的功用: 数据分布 负载均衡读 备份 高可用和故障切换 MySQL升级测试 MySQL复制相关概念 主从复 ...

  9. Sublime Text 全局搜索Ctrl+Shift+F快捷键不能用

      Sublime Text 全局搜索Ctrl+Shift+F快捷键不能用   和微软输入法的简繁体切换冲突了,关闭输入法的简繁体切换快捷键就好了! 文章来源:刘俊涛的博客 欢迎关注,有问题一起学习欢 ...

  10. C之数据类型

    java的数据类型 byte 1个字节 boolean 1个字节 short 2个字节 char 2个字节 int 4个字节 float 4个字节 long 8个字节 double 8个字节 c语言的 ...