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 继承详解(二)
Jul 13 Javascript
Jquery 设置标题的自动翻转
Oct 03 Javascript
js实现全屏漂浮广告移入光标停止移动
Dec 02 Javascript
实例详解angularjs和ajax的结合使用
Oct 22 Javascript
javascript实现uploadify上传格式以及个数限制
Nov 23 Javascript
Vue中之nextTick函数源码分析详解
Oct 17 Javascript
vue-cli 组件的导入与使用教程详解
Apr 11 Javascript
Angular数据绑定机制原理
Apr 17 Javascript
三种Webpack打包方式(小结)
Sep 19 Javascript
JavaScript设计模式之责任链模式实例分析
Jan 16 Javascript
Vue中this.$nextTick的作用及用法
Feb 04 Javascript
ES11新增的这9个新特性,你都掌握了吗
Oct 15 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+MYSQL的文章管理系统(一)
2006/10/09 PHP
用PHP中的 == 运算符进行字符串比较
2006/11/26 PHP
php中判断一个字符串包含另一个字符串的方法
2007/03/19 PHP
smarty中post用法实例
2014/11/28 PHP
浅析Yii2 GridView 日期格式化并实现日期可搜索教程
2016/04/22 PHP
PHP入门教程之正则表达式基本用法实例详解(正则匹配,搜索,分割等)
2016/09/11 PHP
jQuery的链式调用浅析
2010/12/03 Javascript
js获取事件源及触发该事件的对象
2013/10/24 Javascript
jQuery的load()方法及其回调函数用法实例
2015/03/25 Javascript
详解jQuery中的元素的属性和相关操作
2015/08/14 Javascript
网站申请不到支付宝接口、微信接口,免接口收款实现方式几种解决办法
2016/12/14 Javascript
原生JS轮播图插件
2017/02/09 Javascript
Bootstrap轮播图学习使用
2017/02/10 Javascript
js使用highlight.js高亮你的代码
2017/08/18 Javascript
angular4实现tab栏切换的方法示例
2017/10/21 Javascript
vue.js 获取select中的value实例
2018/03/01 Javascript
微信小程序时间标签和时间范围的联动效果
2019/02/15 Javascript
详解如何使用微信小程序云函数发送短信验证码
2019/03/13 Javascript
layer.open提交子页面的form和layedit文本编辑内容的方法
2019/09/27 Javascript
Vue中img的src是动态渲染时不显示的解决
2019/11/14 Javascript
Vue数据双向绑定底层实现原理
2019/11/22 Javascript
django将图片上传数据库后在前端显式的方法
2018/05/25 Python
Python对切片命名的实现方法
2018/10/16 Python
python使用turtle绘制国际象棋棋盘
2019/05/23 Python
十分钟搞定pandas(入门教程)
2019/06/21 Python
Python3内置模块random随机方法小结
2019/07/13 Python
PyCharm中如何直接使用Anaconda已安装的库
2020/05/28 Python
AmazeUI 点击元素显示全屏的实现
2020/08/25 HTML / CSS
澳大利亚制造的蜡烛和扩散器:Glasshouse Fragrances
2018/05/20 全球购物
联强国际笔试题面试题
2013/07/10 面试题
应届毕业生个人求职自荐信
2014/01/06 职场文书
宗教学大学生职业生涯规划范文
2014/02/08 职场文书
运动会通讯稿150字
2014/02/15 职场文书
合伙协议书
2014/04/23 职场文书
工作岗位职责范本
2015/02/15 职场文书
OpenFeign实现远程调用
2022/08/14 Java/Android