vue用户登录状态判断
之前项目中用来判断是否登录我写了多种方案,但是最终只有一个方案是比较好的,这篇博客就是分享该方案;
先说基本要求:
- 项目中的登录状态是依据服务器里的状态来作为判断依据;
- 每一个需要登录后才能操作的接口,如果未登录都会返回未登录的错误;
- 项目中使用 vuex,axios,router;
判断登录方案需要满足下面几点:
- 未登录状态下的刷新:
1.1 在需要登录页面中刷新是需要跳转到登录页的;
1.2 在不需要登录的页面中刷新,不需要跳转; - 在未登录状态下,跳转到需要登录页面时,会直接跳转到登录页;
先在路由文件里修改:
export default {
path: '/person',
component: person,
name: 'person',
redirect: 'person/index',
meta:{
requireLogin:true,
},
children: [
//子页面
]
}
假如上面的代码是一个用户中心的路由,他是主页面,其他都是他的子页面,那么只需要在meta里添加requireLogin:true一次就行了,子页面不需要修改什么;
在 main.js 里添加:
axios.interceptors.response.use(
response => {
if(response.data.code === 500) {
if (response.data.msg === '请先登录') {
router.push({
path: '/login',
query: {redirect: router.history.current.fullPath}
})
//如果需要可以在这里将 vuex 里的 user 改为空对象
}
//显示错误信息
return Promise.reject(response.data)
}
if(response.data.code === 0){
return response;
}
}, error => {
//显示错误信息
return Promise.reject(error.response.data)
});
router.beforeEach((to, from, next) => {
let user = router.app.$options.store.state.user;
if (to.matched.some(record => record.meta.requireLogin)) {
if (JSON.stringify(user) === '{}') {
next();
router.push({ path: '/login',query: { redirect: to.fullPath }})
}else {
next()
}
} else {
next()
}
});
根据 user 是否为一个空对象来判断本地登录状态;
在 app.vue 里添加:
created(){
this.$store.dispatch('getUser');
}
每一次刷新都会触发该函数,作用是判断登录状态和获取最新的信息;
在 vuex/index 添加:
const store = new Vuex.Store({
state: {
user: JSON.parse(localStorage.user || '{}'),
},
mutations: {
changeUser(state, msg){
state.user = msg;
},
},
actions: {
getUser({commit}){
axios.get(api.info).then(data => {
commit('changeUser', data.data.member);//需根据实际修改
localStorage.user = JSON.stringify(data.data.member || {});
}).catch(err => {
commit('changeUser', {});
if (router.currentRoute.matched.some(record => record.meta.requireLogin)) {
router.push({
path: '/login',
query: {redirect: router.currentRoute.fullPath}
})
}
})
},
}
})
在某页面下刷新,可以根据是否为需登录页面进行判断,并且已登录可以更新用户信息;
用户的信息都是存储在 localStorage 里来成为默认值,但是 ajax 连接失败的话,会变为空;
!!注意!!
上面的方法适用的是,不知道后台的登录保存时间,然而,如果你知道后台的登录状态保存时间的话,我想可以有一种更好的方法,即 cookie
因为 cookie 会有一个保存的时间, 进入一个页面判断是否存在;
还可以使用 Web Workers ,在后台添加一个计时器,每一段时间判断 cookie 是否存在,不过 cookie 能存储的东西不多,还有 IE 对Web Workers 是不支持的,所以最好在 main 里判断一下页面是否对 web workers ;
放下我之前项目所用的登录检查方式:
let hasLogin = false // 是否登录过
// 登录拦截
router.beforeEach((to, from, next) => {
if (document.cookie.includes('userName')) {
hasLogin = true
if (permission.indexOf(to.path) > -1) {
next()
} else {
try {
// 简单的权限判断
let routesKey = Cookie.get('routesKey').split(',')
let key = to.path.split('/')[1]
if (routesKey.indexOf(key) > -1) {
next()
} else {
next({path: '/'})
}
} catch (e) {
next({path: '/login'})
}
}
} else {
if (to.path === '/login') { // 如果是登录页面路径,就直接next()
next()
} else {
if (hasLogin) {
Cookie.clear('userName')
ELEMENT.Message({
message: '登录失效,请重新登录!',
center: true,
type: 'warning'
})
}
next({path: '/login', query: {redirect: to.fullPath}})
}
}
})
完;
vue用户登录状态判断的更多相关文章
- C# MVC 用户登录状态判断 【C#】list 去重(转载) js 日期格式转换(转载) C#日期转换(转载) Nullable<System.DateTime>日期格式转换 (转载) Asp.Net MVC中Action跳转(转载)
C# MVC 用户登录状态判断 来源:https://www.cnblogs.com/cherryzhou/p/4978342.html 在Filters文件夹下添加一个类Authenticati ...
- C# MVC 用户登录状态判断
来源:https://www.cnblogs.com/cherryzhou/p/4978342.html 在Filters文件夹下添加一个类AuthenticationAttribute ,代码如下: ...
- iOS开发之记录用户登录状态
iOS开发之记录用户登录状态 我们知道:CoreData的配置和使用步骤还是挺复杂的.但熟悉CoreData的使用流程后,CoreData还是蛮好用的.今天要说的是如何记录我们用户的登陆状态.例如微信 ...
- Asp.Net使用加密cookie代替session验证用户登录状态 源码分享
首先 session 和 cache 拥有各自的优势而存在. 他们的优劣就不在这里讨论了. 本实例仅存储用户id于用户名,对于多级权限的架构,可以自行修改增加权限字段 本实例采用vs2010编写 ...
- SpringBoot29 登录逻辑、登录状态判断
1 知识点扫盲 浏览器和服务器之间时通过session来确定连接状态的,浏览器第一次请求时服务端会自动生成一个session,并将这个sessionId传回给浏览器,浏览器将这个sessionId存放 ...
- Django 用Session和Cookie分别实现记住用户登录状态
简介 由于http协议的请求是无状态的.故为了让用户在浏览器中再次访问该服务端时,他的登录状态能够保留(也可翻译为该用户访问这个服务端其他网页时不需再重复进行用户认证).我们可以采用Cookie或Se ...
- 基于cookie的用户登录状态管理
cookie是什么 先来花5分钟看完这篇文章:https://developer.mozilla.org/zh-CN/docs/Web/HTTP/Cookies 看完上文,相信大家对cookie已经有 ...
- vue 根据接口返回的状态码判断用户登录状态并跳转登录页,登录后回到上一个页面(http拦截器)
背景:后台接口返回code==501表示用户是未登录状态,需要登录才可访问: 通过http拦截做路由跳转 第一步:src目录下新建http.js文件,内容如下: import Axios from ' ...
- iOS - 记住用户登录状态保存用户名密码
我们在使用APP时常用的一个功能:用户第一次进入APP时自动进入登录注册页,提示用户注册登录,用户登录成功后才进入主页,再次进入APP时,不用再次登录就直接进到主页了,就算杀掉该APP进程再次进入,依 ...
随机推荐
- tarjan 割点 割边
by GeneralLiu tarjan 求 割点 割边 无向图 的 割点 割边: 对于无向连通图来说, 如果删除 一个点以及与它相连的边 之后, 使得这个图不连通, 那么该点为割点 : ...
- [BZOJ3932] [CQOI2015]任务查询系统(主席树 || 树状数组 套 主席树 + 差分 + 离散化)
传送门 看到这个题有个很暴力的想法, 可以每一个时间点都建一颗主席树,主席树上叶子节点 i 表示优先级为 i 的任务有多少个. 当 x 到 y 有个优先级为 k 的任务时,循环 x 到 y 的每个点, ...
- hdu 5044 树链剖分
转载:http://blog.csdn.net/qinzhenhua100/article/details/39716851 二种操作,一种更新结点值,一种更新路径值,最后输出更改后的结点值和路径值. ...
- springboot 子模块访问不到对应的页面
出现如下错误 解决方案 working directory:没有$MODULE_DIR$该选项,自己输入即可. 完成以上操作就可以正常访问页面了.
- 【.Net 学习系列】-- Windows服务定时运行,判断当前时间是否在配置时间段内
/// <summary> /// 判断程序是否在设置运行时间内 /// </summary> /// <param name="startTime" ...
- 表单验证的完美解决方案Validform
具体使用方法参考官网介绍吧,相当的简单: 文档:http://validform.rjboy.cn/document.html demo:http://validform.rjboy.cn/demo. ...
- flask到底能登录多少用户?
flask默认情况下是单进程的,所以每次只能处理一个请求: 当然可以多起几个进程或者线程,这样flask就可以处理多个请求: 认证后的用户,进行一次操作(一个GET操作.一次POST操作或者其他),会 ...
- Centos 备份 还原
備份: tar cvpzf backup.tgz / --exclude=/backup.tgz --exclude=/mnt 記得一定要排除備份文件本身哦! 還原: tar xvpfz backup ...
- hdu 2544 最短路(SPFA算法)
本题链接:点击打开链接 本题大意: 首先输入一个n,m.代表有n个点.m条边.然后输入m条边,每条边输入两个点及边权.1为起点,n为终点.输入两个零表示结束. 解题思路: 本题能够使用SPFA算法来做 ...
- 【Android归纳】回调机制在Android中的应用与实战
回调这样的思想在程序中是比較普遍的.有时候可能我们并没有注意到.近期整理了一些对于回调的理解,分享给大家 先上概念...... 什么是回调函数? 回调函数就是一个通过函数指针调用的函数. 假设你把函数 ...