uniapp登录拦截器

简介: uniapp登录拦截器

uni.addInterceptor是uni-app官网提供的拦截器,可以利用它来实现登录拦截器,用户在没有登录时是无法进行其他操作的。

image.png

在根目录下新建一个index.js,或者新建一个文件夹,在文件夹中新建index.js。

image.png

//只要是未登录状态,想要跳转到名单内的路径时,直接跳到登录页
// 页面白名单,不受拦截
const whiteList = [
  '/pages/my/my'
]
function hasPermission (url) {
  let islogin = sessionStorage.getItem("isLogin");//在这可以使用token、vuex
  islogin = Boolean(Number(islogin));//返回布尔值
    // 在白名单中或有登录判断条件可以直接跳转
    if(whiteList.indexOf(url) !== -1 || islogin) {
        return true
    }
    return false
}
uni.addInterceptor('navigateTo', {
    // 页面跳转前进行拦截, invoke根据返回值进行判断是否继续执行跳转
    invoke (e) {
        if(!hasPermission(e.url)){
            uni.reLaunch({
                url: '/pages/my/my'
            })
            return false
        }
        return true
    },
    success (e) {
    }
})
uni.addInterceptor('switchTab', {
    // tabbar页面跳转前进行拦截
    invoke (e) {
        if(!hasPermission(e.url)){
            uni.reLaunch({
                url: '/pages/my/my'
            })
            return false
        }
        return true
    },
    success (e) {
    }
})

main.js中引用。

import './router/index';//引入拦截

登录界面利用sessionStorage存储登录判断条件。

sessionStorage.setItem('isLogin',1);//登录判断

这样就简单的实现了登录拦截!!!


相关文章
|
3月前
|
前端开发 JavaScript 应用服务中间件
【uniapp】谷歌授权登录,前端uniapp直调(含源码)
本文介绍如何在uniapp项目中实现谷歌授权登录,无需后端参与。文章分为三部分:1)谷歌授权登录流程,详细说明从用户点击登录到获取用户信息的整个过程;2)谷歌开发者控制台配置,包括创建项目、配置同意屏幕及OAuth客户端ID等步骤;3)uniapp前端实操,提供具体代码示例,展示如何获取授权码并用其交换访问令牌,最终获取用户信息
150 2
【uniapp】谷歌授权登录,前端uniapp直调(含源码)
|
3月前
|
存储 前端开发 安全
|
3月前
|
存储 小程序 JavaScript
|
3月前
|
开发工具 Android开发
|
3月前
|
小程序 前端开发 安全
|
3月前
|
存储 前端开发 Java
|
5月前
uniapp简单的登录页面布局
uniapp简单的登录页面布局
132 1
|
4月前
uniapp 登录
uniapp 登录
30 0
|
6月前
|
前端开发
uniapp 实现退出登录 清除Token
uniapp 实现退出登录 清除Token
185 0
|
6月前
|
API
uniapp怎么实现授权登录
uniapp怎么实现授权登录
197 2