【工作实践-11】关于uniapp切换账号登录失败问题

遇到问题:在使用uniapp写的程序中,第一次打开程序登录(账号密码正确),调用登录接口,没有任何问题,正常登录;退出登陆后,输入不同的账号密码(账号密码均正确),调用登录接口提示登陆失败。很迷惑。

**揭露原因:**第一次登陆时查看接口详细信息,发现请求头中header携带的token为空,第二次用不同的账号密码登录时,接口请求头中header携带的token是第一次登录用户的token。前端在调用接口时,如果携带token,后端会通过判断token值来拦截请求,此时第一次的token与第二次登录用户的token不一致,所以导致登陆失败的结果。

**如何修改:**知道原因后,看了请求封装中的代码

javascript 复制代码
const isToken = withToken === false     // withToken表示此接口是否需要token
if (!isToken) {
			const token = uni.getStorageSync('AccessTokenKey')
			if (!token) {
				uni.showModal({
					title: '登录',
					content: '该功能需要登录后访问',
					showCancel: false,
					success(res) {
						if (res.confirm) {
							uni.reLaunch({
								url: `/pages/login/login`,
							})
						}
					}
				})
			} else {
				config.header['Authorization'] = `Bearer ${token}`
			}
		}

我们知道登录接口是不需要携带token的,所以登录接口中withToken值为false,此时不会进入上面对的 if 判断,即不会对config的header做任何处理。所以第一次登录不会有任何问题。

第一次登陆成功后,用户通过登录接口请求到了自己的token。退出登录后,第二个用户登录(账号密码均正确),即使此时withToken值依旧为false,但由于不进入 if 判断,没有对header做任何处理,所以此时的 header 依旧是上一个请求接口的 header 信息,token也是上一个用户的 token 信息,提示登录失败。

**修正代码:**对if判断添加else分支,并对header的token信息做置空操作

javascript 复制代码
        const isToken = withToken === false
		if (!isToken) {
			const token = uni.getStorageSync('AccessTokenKey')
			if (!token) {
				uni.showModal({
					title: '登录',
					content: '该功能需要登录后访问',
					showCancel: false,
					success(res) {
						if (res.confirm) {
							uni.reLaunch({
								url: `/pages/login/login`,
							})
						}
					}
				})
			} else {
				config.header['Authorization'] = `Bearer ${token}`
			}
		} else {
			config.header['Authorization'] = ''
		}

**收获:**在写 if 或其它任何条件分支的代码时,一定要综合考虑多种情况,争取尽可能的考虑完善,避免疏漏。

相关推荐
HashTang6 小时前
【AI 编程实战】第 12 篇:从 0 到 1 的回顾 - 项目总结与 AI 协作心得
前端·uni-app·ai编程
JunjunZ9 小时前
uniapp 文件预览:从文件流到多格式预览的完整实现
前端·uni-app
郑州光合科技余经理1 天前
代码展示:PHP搭建海外版外卖系统源码解析
java·开发语言·前端·后端·系统架构·uni-app·php
TT_Close1 天前
“啪啪啪”三下键盘,极速拉起你的 uni-app 项目!
vue.js·uni-app·前端工程化
特立独行的猫a1 天前
uni-app x跨平台开发实战:开发鸿蒙HarmonyOS影视票房榜组件完整实现过程
华为·uni-app·harmonyos·轮播图·uniapp-x
00后整顿职场1 天前
Hbuilderx APP真机无法识别iqoo Z9+手机设备解决方案
uni-app·uniapp真机调试·真机运行
前端小雪的博客.1 天前
【保姆级教程】uniAI 插件高效开发 uni-app 微信小程序(附实战案例)
微信小程序·uni-app·ai编程·uniai
T^T尚1 天前
一个完整的项目怎么打包成为一个app
前端·uni-app
阿巴资源站1 天前
uniapp加水印
java·前端·uni-app
特立独行的猫a1 天前
uni-app x跨平台开发实战:开发鸿蒙HarmonyOS滚动卡片组件,scroll-view无法滚动踩坑全记录
华为·uni-app·harmonyos·uniapp-x