uniapp路由守卫

创建auth.js文件(utils/auth.js)

// 白名单
const whiteList = ['/pages/Login/loginHome', '/pages/Login/Login','/pages/Login/phoneLogin','/pages/Login/register/register']
 
export default async function() {
	const list = ['navigateTo', 'redirectTo', 'reLaunch', 'switchTab']
	list.forEach(item => {
		uni.addInterceptor(item, {
			invoke(e) {
			    // 获取要跳转的页面路径
				const url = e.url.split('?')[0]
				// 判断当前窗口是白名单,如果是则不重定向路由
				var pass = false
				if (whiteList) {
					pass = whiteList.indexOf(url) != -1
				}
				// 不是白名单并且没有token
				if (!pass && !uni.getStorageSync('token')) {
					uni.showToast({
						title: '用户信息过期 请重新登录登录',
						icon: 'none'
					})
					setTimeout(() => {
						uni.redirectTo({
							url: '/pages/Login/loginHome'
						});
					}, 3000);
					return false
				}
				return e
			},
			fail(err) { // 失败回调拦截
				console.log(err)
			}
		})
	})
}

在App.uvue文件

import auth from '@/utils/auth.js'

export default {
	onLaunch: function () {
		auth()
	}
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值