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中top、clientTop、scrollTop、offsetTop的区别 文字详细说明版
Jan 08 Javascript
js substr支持中文截取函数代码(中文是双字节)
Apr 17 Javascript
Javascript 按位与运算符 (&amp;)使用介绍
Feb 04 Javascript
javascript内置对象arguments详解
Mar 16 Javascript
跟我学习javascript的call(),apply(),bind()与回调
Nov 16 Javascript
浅析JavaScript中的变量复制、参数传递和作用域链
Jan 13 Javascript
jQuery ajax方法传递中文时出现中文乱码的解决方法
Jul 25 Javascript
Mac下安装vue
Apr 11 Javascript
jQuery.extend 与 jQuery.fn.extend的用法及区别实例分析
Jul 25 jQuery
基于vue2.0的活动倒计时组件countdown(附源码下载)
Oct 09 Javascript
vuex 解决报错this.$store.commit is not a function的方法
Dec 17 Javascript
node.js express捕获全局异常的三种方法实例分析
Dec 27 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
ajax php传递和接收变量实现思路及代码
2012/12/19 PHP
PHP输出当前进程所有变量/常量/模块/函数/类的示例
2013/11/07 PHP
ThinkPHP中session函数详解
2016/09/14 PHP
微信接口生成带参数的二维码
2017/07/31 PHP
$.ajax json数据传递方法
2008/11/19 Javascript
javascript 操作文件 实现方法小结
2009/07/02 Javascript
将数字转换成大写的人民币表达式的js函数
2014/09/21 Javascript
Jquery操作Ajax方法小结
2015/11/29 Javascript
js重写方法的简单实现
2016/07/10 Javascript
Nodejs抓取html页面内容(推荐)
2016/08/11 NodeJs
JS实现div模块的截图并下载功能
2017/10/17 Javascript
jquery animate动画持续运动的实例
2017/11/29 jQuery
浅谈Node.js爬虫之网页请求模块
2018/01/11 Javascript
vue插件开发之使用pdf.js实现手机端在线预览pdf文档的方法
2018/07/12 Javascript
Vue + element 实现多选框组并保存已选id集合的示例代码
2020/06/03 Javascript
微信h5静默和非静默授权获取用户openId的方法和步骤
2020/06/08 Javascript
vue 导航守卫和axios拦截器有哪些区别
2020/12/19 Vue.js
python实现去除下载电影和电视剧文件名中的多余字符的方法
2014/09/23 Python
Python使用time模块实现指定时间触发器示例
2017/05/18 Python
Python使用struct处理二进制的实例详解
2017/09/11 Python
分析Python读取文件时的路径问题
2018/02/11 Python
python线程池threadpool使用篇
2018/04/27 Python
解决pandas无法在pycharm中使用plot()方法显示图像的问题
2018/05/24 Python
win8下python3.4安装和环境配置图文教程
2018/07/31 Python
Python 访问限制 private public的详细介绍
2018/10/16 Python
python中struct模块之字节型数据的处理方法
2019/08/27 Python
详解Python图像处理库Pillow常用使用方法
2019/09/02 Python
Agoda香港:全球特价酒店预订
2017/05/07 全球购物
科茨沃尔德家居商店:Scotts of Stow
2018/06/29 全球购物
Michael Kors英国官网:美国奢侈品品牌
2019/11/13 全球购物
PHP开发的一般流程
2013/08/13 面试题
优秀部门获奖感言
2014/02/14 职场文书
学习十八届三中全会精神实施方案
2014/02/17 职场文书
2016党校学习心得体会
2016/01/07 职场文书
Pytorch中Softmax与LogSigmoid的对比分析
2021/06/05 Python
python实现会员信息管理系统(List)
2022/03/18 Python