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 相关文章推荐
js利用div背景,做一个竖线的效果。
Nov 22 Javascript
JavaScript类和继承 constructor属性
Mar 04 Javascript
firefox事件处理之自动查找event的函数(用于onclick=foo())
Aug 05 Javascript
基于PHP+Jquery制作的可编辑的表格的代码
Apr 10 Javascript
javascript委托(Delegate)blur和focus用法实例分析
May 26 Javascript
javascript中return,return true,return false三者的用法及区别
Nov 17 Javascript
js实现ctrl+v粘贴上传图片(兼容chrome、firefox、ie11)
Mar 09 Javascript
5个最顶级jQuery图表类库插件【jquery插件库】
May 05 Javascript
three.js实现3D影院的原理的代码分析
Dec 18 Javascript
ExtJs整合Echarts的示例代码
Feb 27 Javascript
Vue实现页面添加水印功能
Nov 09 Javascript
JavaScript实现简单计算器功能
Dec 19 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
PHP采集腾讯微博的实现代码
2012/01/19 PHP
Linux中用PHP判断程序运行状态的2个方法
2014/05/04 PHP
PHP中遇到的时区问题解决方法
2015/07/23 PHP
tp5框架的增删改查操作示例
2019/10/31 PHP
JavaScript window.document的属性、方法和事件小结
2012/10/24 Javascript
js操作label给label赋值及取label的值示例
2013/11/07 Javascript
JQuery实现的按钮倒计时效果
2015/12/23 Javascript
JS设置cookie、读取cookie
2016/02/24 Javascript
jquery简单插件制作(fn.extend)完整实例
2016/05/24 Javascript
node.js 抓取代理ip实例代码
2017/04/30 Javascript
node的process以及child_process模块学习笔记
2018/03/06 Javascript
mpvue中配置vuex并持久化到本地Storage图文教程解析
2018/03/15 Javascript
vue组件实现可搜索下拉框扩展
2020/10/23 Javascript
Vue组件系列开发之模态框
2019/04/18 Javascript
详解vue-router的Import异步加载模块问题的解决方案
2020/05/13 Javascript
浅谈vue的第一个commit分析
2020/06/08 Javascript
vue 使用lodash实现对象数组深拷贝操作
2020/09/10 Javascript
uniapp实现可以左右滑动导航栏
2020/10/21 Javascript
python开发环境PyScripter中文乱码问题解决方案
2016/09/11 Python
python实现报表自动化详解
2017/11/16 Python
详解Python3之数据指纹MD5校验与对比
2019/06/11 Python
python 3.6.7实现端口扫描器
2019/09/04 Python
PyQt5连接MySQL及QMYSQL driver not loaded错误解决
2020/04/29 Python
在HTML5中如何使用CSS建立不可选的文字
2014/10/17 HTML / CSS
Made in Design德国:设计师家具、灯具和装饰
2019/10/31 全球购物
Android面试宝典
2013/08/06 面试题
Ruby中的保护方法和私有方法与一般面向对象程序设计语言的一样吗
2013/05/01 面试题
自我鉴定思想方面
2013/10/07 职场文书
留学自荐信写作方法
2014/01/27 职场文书
医院节能减排方案
2014/06/13 职场文书
爬山的活动方案
2014/08/16 职场文书
党员三严三实对照检查材料
2014/10/13 职场文书
党员思想汇报材料
2014/12/19 职场文书
2015年教师节感恩寄语
2015/03/23 职场文书
Go语言中的UTF-8实现
2021/04/26 Golang
解决flex布局中子项目尺寸不受flex-shrink限制
2022/05/11 HTML / CSS