Vue设置长时间未操作登录自动到期返回登录页


Posted in Javascript onJanuary 22, 2020

Vue设置长时间未操作登录以后自动到期返回登录页

首先我们写在main.js文件中

import routerUtil from "@/utils/routerutil";//先将js文件在main.js中引入
routerUtil(router);

我们会在登陆成功后调用sessionUtil文件中的setSession,sessionUtil下面写的有

import sessionUtil from '@/utils/sessionutil'
sessionUtil.setSession("userInfo", '2');

在routerutil.js文件中

import sessionUtil from "./sessionutil";
const whiteList = ["/",'/logins']; // 路由白名单,不需要校验

export default router => {
 router.beforeEach(async (to, from, next) => {/*在跳转之前执行*/
 const userInfo = sessionUtil.getSession("userInfo");//触发sessionUtil中的getSession方法
 if ( userInfo ) {
 ////
 } else {
 if (whiteList.indexOf(to.path) !== -1) {
  next();
 } else {
  Message({
  type: "warning",
  message: "用户登录过期,请重新登录",
  duration: 1500,
  onClose() {
   next(`/`);
  }
  });
 }
 }
 });
};

在sessionutil.js文件中

const sessionutil = {
 setSession(key,value,maxAge){ //key=userInfo value=2 maxAge='' || 可自行设置
 const maxAgeTime = new Date().getTime() + 1000 * 3600; // 当前时间的+1小时 session 过期时间
 try{
  let data = { value, maxAge: maxAge ? maxAge : maxAgeTime }
  sessionStorage.setItem(typeof key === 'string'?key: JSON.stringify(key),JSON.stringify(data))
 }catch(err){
 }
 },
 getSession(key){
 try{
  const maxAgeTime = new Date().getTime() + 1000 * 3600; // 首先先设置一个 session 过期时间 1H后可自行设置
  let date = new Date().getTime(); //当前时间
  let session = JSON.parse(sessionStorage.getItem(typeof key === 'string'?key: JSON.stringify(key))); 
  if(session && session.maxAge != null && session.maxAge-date > 0 && session.maxAge <= maxAgeTime ){
  this.setSession(key,session.value);
  return session.value;
  } else {
  return null;
  }
 }catch(err){
 }
 },
}
export default sessionutil;

总结

以上所述是小编给大家介绍的Vue设置长时间未操作登录自动到期返回登录页,希望对大家有所帮助!

Javascript 相关文章推荐
[推荐]javascript 面向对象技术基础教程
Mar 03 Javascript
JavaScript获取页面上某个元素的代码
Mar 13 Javascript
jquery中ajax调用json数据的使用说明
Mar 17 Javascript
网页编辑器ckeditor和ckfinder配置步骤分享
May 24 Javascript
XMLHttpRequest处理xml格式的返回数据(示例代码)
Nov 21 Javascript
js实现兼容IE和FF的上下层的移动
May 04 Javascript
jQuery中(function($){})(jQuery)详解
Jul 15 Javascript
js窗口关闭提示信息(兼容IE和firefox)
Oct 23 Javascript
Angular2学习笔记——详解路由器模型(Router)
Dec 02 Javascript
详解在React中跨组件分发状态的三种方法
Aug 09 Javascript
微信小程序云开发之使用云数据库
May 17 Javascript
JS实现4位随机验证码
Oct 19 Javascript
JavaScript设计模型Iterator实例解析
Jan 22 #Javascript
Vue开发环境跨域访问问题
Jan 22 #Javascript
vue中英文切换实例代码
Jan 21 #Javascript
微信小程序点击view动态添加样式过程解析
Jan 21 #Javascript
微信小程序如何实现radio单选框单击打勾和取消
Jan 21 #Javascript
微信小程序仿淘宝热搜词在搜索框中轮播功能
Jan 21 #Javascript
微信小程序swiper实现文字纵向轮播提示效果
Jan 21 #Javascript
You might like
SSI指令
2006/11/25 PHP
php 调用百度sms来发送短信的实现示例
2018/11/02 PHP
jQuery 学习第五课 Ajax 使用说明
2010/05/17 Javascript
JS控制表格实现一条光线流动分割行的方法
2015/03/09 Javascript
jQuery实现简洁的导航菜单效果
2015/11/23 Javascript
js实现城市级联菜单的2种方法
2017/06/23 Javascript
Nodejs连接mysql并实现增、删、改、查操作的方法详解
2018/01/04 NodeJs
Javascript中prototype与__proto__的关系详解
2018/03/11 Javascript
vue移动端监听滚动条高度的实现方法
2018/09/03 Javascript
对angular2中的ngfor和ngif指令嵌套实例讲解
2018/09/12 Javascript
记一次vue去除#问题处理经过小结
2019/01/24 Javascript
JS事件流与事件处理程序实例分析
2019/08/16 Javascript
在Angular项目使用socket.io实现通信的方法
2021/01/05 Javascript
python 字符串格式化代码
2013/03/17 Python
python Django框架实现自定义表单提交
2016/03/25 Python
Python实现将照片变成卡通图片的方法【基于opencv】
2018/01/17 Python
python导入pandas具体步骤方法
2019/06/23 Python
python设置环境变量的原因和方法
2019/06/24 Python
python2.7的flask框架之引用js&amp;css等静态文件的实现方法
2019/08/22 Python
Python列表list操作相关知识小结
2020/01/29 Python
Python SMTP发送电子邮件的示例
2020/09/23 Python
html5定制表单_动力节点Java学院整理
2017/07/11 HTML / CSS
英国的知名精品百货公司:House of Fraser(福来德)
2016/08/14 全球购物
aden + anais官方网站:婴儿襁褓、毯子、尿布和服装
2017/06/21 全球购物
便携式太阳能系统的创新者:GOAL ZERO
2018/02/04 全球购物
大学生毕业求职找工作的自我评价
2013/09/29 职场文书
五年级音乐教学反思
2014/02/06 职场文书
阳光体育活动总结
2014/04/30 职场文书
公开承诺书格式
2014/05/21 职场文书
小学学校评估方案
2014/06/08 职场文书
五好家庭申报材料
2014/12/20 职场文书
MySQL Shell的介绍以及安装
2021/04/24 MySQL
解决go在函数退出后子协程的退出问题
2021/04/30 Golang
教你怎么用PyCharm为同一服务器配置多个python解释器
2021/05/31 Python
Python机器学习之基于Pytorch实现猫狗分类
2021/06/08 Python
Python绘制散点图之可视化神器pyecharts
2022/07/07 Python