vue通过cookie获取用户登录信息的思路详解


Posted in Javascript onOctober 30, 2018

思路

  • 进入页面
  • 若未登录,跳转至登陆页面
  • 若已登录,从cookie中获取用户信息,并执行后续操作

2. 登录页面,存入cookie(setCookie)

import {setCookie,getCookie}from 'src/js/cookieUtil'
 methods: {
  async cheack_n_p () {
   if( this.checkCode === this.pwd) {
    this.loginData = await getUserInfo(this.uname, this.pwd, this.adminPhone);
    if (this.loginData.res !== 0) {
     setCookie('userName',this.uname);
     setCookie('userPwd',this.pwd,);
     setCookie('phone',this.uname);
     setCookie('userId',this.loginData.obj.id);
     setCookie('userType',this.loginData.obj.userType);
     setCookie('adminPhone',this.adminPhone);
//    this.$router.go(-1);
     this.$router.replace('/');
    } else {
     alert("验证码错误!")
    }
   }
  },
  //验证手机号码部分
  async sendcode(){
   var pattern = /^0{0,1}(1[0-9][0-9]|15[7-9]|153|156|18[7-9])[0-9]{8}$/,
    str =this.uname;
   if (!pattern.test(str)) {
    alert('请正确输入手机号!');
    return ;
   }
   this.time=60;
   this.disabled=true;
   this.timer();
   this.checkCode = (await getUserPhoneCode(this.uname)).resMsg;
   // this.checkCode = '123456';
   console.log( this.checkCode)
  },
  timer:function () {
   if (this.time > 0) {
    this.time--;
//         console.log(this.time);
    this.btntxt=this.time+"s后重新获取";
    setTimeout(this.timer, 1000);
   } else{
    this.time=0;
    this.btntxt="获取验证码";
    this.disabled=false;
   }
  }
 },

2. 页面判断

import {setCookie,getCookie}from 'src/js/cookieUtil'
 mounted () {
  if (this.isLogin==undefined||this.isLogin=="") {
   this.$router.replace('/login');
  } else {
   // 执行后续操作
   this.phone = getCookie("phone");
   }
 },
 computed: {
  isLogin () {
   // return this.$store.getters.getLogin;
   this.userId = getCookie("userId");
   // console.log(this.userId);
   return this.userId;
  }
 },

3. cookieUtil(setCookie,getCookie)

/**
 * Created by Schon on 2018/9/13 0013.
 */
//设置cookie
export function setCookie(key,value) {
 var exdate = new Date(); //获取时间
 exdate.setTime(exdate.getTime() + 24 * 60 * 60 * 1000 * 36500); //保存的天数,我这里写的是100年
 //字符串拼接cookie
 window.document.cookie = key + "=" + value + ";path=/;expires=" + exdate.toGMTString();
};
//读取cookie
export function getCookie(param) {
 var c_param = '';
 if (document.cookie.length > 0) {
  var arr = document.cookie.split('; '); //这里显示的格式需要切割一下自己可输出看下
  for (var i = 0; i < arr.length; i++) {
   var arr2 = arr[i].split('='); //再次切割
   //判断查找相对应的值
   if (arr2[0] == param) {
    c_param = arr2[1];
    //保存到保存数据的地方
   }
  }
  return c_param;
 }
};
function padLeftZero (str) {
 return ('00' + str).substr(str.length);
};

总结

以上所述是小编给大家介绍的vue通过cookie获取用户登录信息的思路详解,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

Javascript 相关文章推荐
JavaScript检测实例属性, 原型属性
Feb 04 Javascript
JS实现支持多选的遍历下拉列表代码
Aug 20 Javascript
JavaScript测试工具之Karma-Jasmine的安装和使用详解
Dec 03 Javascript
利用js定义一个导航条菜单
Mar 14 Javascript
JS数组搜索之折半搜索实现方法分析
Mar 27 Javascript
web前端vue filter 过滤器
Jan 12 Javascript
Vue render渲染时间戳转时间,时间转时间戳及渲染进度条效果
Jul 27 Javascript
vue 使用element-ui中的Notification自定义按钮并实现关闭功能及如何处理多个通知
Aug 17 Javascript
vue实现百度搜索功能
Dec 28 Javascript
Vue组件通信入门之Provide和Inject机制
Dec 29 Javascript
Vue 实现分页与输入框关键字筛选功能
Jan 02 Javascript
bootstrap-closable-tab可实现关闭的tab标签页插件
Aug 09 Javascript
微信小程序实现左滑修改、删除功能
Oct 19 #Javascript
小程序实现列表删除功能
Oct 30 #Javascript
require.js 加载过程与使用方法介绍
Oct 30 #Javascript
小程序实现左滑删除功能
Oct 30 #Javascript
提升node.js中使用redis的性能遇到的问题及解决方法
Oct 30 #Javascript
小程序云开发部署攻略(图文教程)
Oct 30 #Javascript
傻瓜式解读koa中间件处理模块koa-compose的使用
Oct 30 #Javascript
You might like
浅析memcache启动以及telnet命令详解
2013/06/28 PHP
WordPress主题制作中自定义头部的相关PHP函数解析
2016/01/08 PHP
php使用escapeshellarg时中文被过滤的解决方法
2016/07/10 PHP
用javascript实现分割提取页面所需内容
2007/05/09 Javascript
发布一个高效的JavaScript分析、压缩工具 JavaScript Analyser
2007/11/30 Javascript
js对象的比较
2011/02/26 Javascript
一个支持任意尺寸的图片上下左右滑动效果
2014/08/24 Javascript
jQuery选择器源码解读(六):Sizzle选择器匹配逻辑分析
2015/03/31 Javascript
jQuery实现横向带缓冲的水平运动效果(附demo源码下载)
2016/01/29 Javascript
微信小程序中时间戳和日期的相互转换问题
2018/07/09 Javascript
在JS循环中使用async/await的方法
2018/10/12 Javascript
解决 window.onload 被覆盖的问题方法
2020/01/14 Javascript
node.js中module模块的功能理解与用法实例分析
2020/02/14 Javascript
Vue-resource安装过程及使用方法解析
2020/07/21 Javascript
vue 实现element-ui中的加载中状态
2020/11/11 Javascript
[44:26]DOTA2上海特级锦标赛主赛事日 - 2 胜者组第一轮#4EG VS Fnatic第二局
2016/03/03 DOTA
[59:30]完美世界DOTA2联赛PWL S3 access vs LBZS 第二场 12.20
2020/12/23 DOTA
如何运行Python程序的方法
2013/04/21 Python
python基于pygame实现响应游戏中事件的方法(附源码)
2015/11/11 Python
简单谈谈Python中函数的可变参数
2016/09/02 Python
Python Web框架之Django框架Model基础详解
2019/08/16 Python
Python函数的迭代器与生成器的示例代码
2020/06/18 Python
Pandas的Apply函数具体使用
2020/07/21 Python
机关会计岗位职责
2014/04/08 职场文书
品质口号大全
2014/06/17 职场文书
奉献家乡演讲稿
2014/09/16 职场文书
学生自我鉴定格式及范文
2014/09/16 职场文书
科学发展观标语
2014/10/08 职场文书
2014年会计人员工作总结
2014/12/10 职场文书
留学推荐信英文范文
2015/03/26 职场文书
经营场所使用证明
2015/06/19 职场文书
新闻发布会新闻稿
2015/07/17 职场文书
大学校园招聘会感想
2015/08/10 职场文书
MySQL主从复制断开的常用修复方法
2021/04/07 MySQL
电脑关机速度很慢怎么办 提升电脑关机速度设置教程
2022/04/08 数码科技
js 实现Material UI点击涟漪效果示例
2022/09/23 Javascript