【工作实践-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 或其它任何条件分支的代码时,一定要综合考虑多种情况,争取尽可能的考虑完善,避免疏漏。

相关推荐
Martin -Tang1 天前
uniapp+vue3+ts自定义表格
javascript·vue.js·uni-app
LinMin_Rik2 天前
解决win11专业版HbuilderX编译vue3的uniappX失败问题
uni-app
游戏开发爱好者82 天前
iOS应用性能监控:Pre-Main与Main函数耗时分析及Time Profiler使用教程
android·ios·小程序·https·uni-app·iphone·webview
西洼工作室3 天前
个人开发者接入阿里云号码认证服务AliCloud-NirvanaPns实现一键登录
python·阿里云·uni-app·全栈·认证授权
2501_916008893 天前
ChatGPT前端开发学习指南:Visual Studio Code与谷歌浏览器安装配置详解
ide·vscode·ios·小程序·uni-app·编辑器·iphone
2501_915909063 天前
完整指南:如何将iOS应用上架到App Store
android·ios·小程序·https·uni-app·iphone·webview
xiangxiongfly9154 天前
uni-app 组件总结
前端·javascript·uni-app
2501_915918414 天前
iOS性能数据监控:从概念到工具实践,让应用运行更流畅
android·macos·ios·小程序·uni-app·cocoa·iphone
2501_915909065 天前
全面解析前端开发中常用的浏览器调试工具及其使用场景
android·ios·小程序·https·uni-app·iphone·webview
wuxianda10305 天前
uniapp项目上架苹果商店4.3a被拒,3天极速解决方案2026.5.8
前端·人工智能·flutter·uni-app·ios上架·苹果上架·苹果4.3a