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 06 Javascript
JS实现点击下载的小例子
Jul 10 Javascript
jQuery让控件左右移动的三种实现方法
Sep 08 Javascript
JS实现金额转换(将输入的阿拉伯数字)转换成中文的实现代码
Sep 30 Javascript
javascript修改表格背景色实例代码分享
Dec 10 Javascript
jQuery获取及设置表单input各种类型值的方法小结
May 24 Javascript
详解从Node.js的child_process模块来学习父子进程之间的通信
Mar 27 Javascript
微信小程序 蓝牙的实现实例代码
Jun 27 Javascript
基于Vue制作组织架构树组件
Dec 06 Javascript
CentOS环境中MySQL修改root密码方法
Jan 07 Javascript
详解Angular操作cookies方法
Jun 01 Javascript
公众号SVG动画交互实战代码
May 31 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对图像的各种处理函数代码小结
2013/07/08 PHP
采用thinkphp自带方法生成静态html文件详解
2014/06/13 PHP
PHP中的reflection反射机制测试例子
2014/08/05 PHP
javascript之更有效率的字符串替换
2008/08/02 Javascript
利用Javascript判断操作系统的类型实现不同操作系统下的兼容性
2013/01/29 Javascript
JavaScript声明变量时为什么要加var关键字
2014/09/29 Javascript
js兼容pc端浏览器并有多种弹出小提示的手机端浮层控件实例
2015/04/29 Javascript
javascript判断图片是否加载完成的方法推荐
2016/05/13 Javascript
jQuery实现下拉框多选 jquery-multiselect 的实例代码
2016/07/14 Javascript
JavaScript判断数组是否存在key的简单实例
2016/08/03 Javascript
基于HTML+CSS+JS实现增加删除修改tab导航特效代码
2016/08/05 Javascript
BootStrap Table 获取同行不同列元素的方法
2016/12/19 Javascript
JS中mouseup事件丢失的原因与解决办法
2017/06/14 Javascript
微信小程序loading组件显示载入动画用法示例【附源码下载】
2017/12/09 Javascript
JS基于封装函数实现的表格分页完整示例
2018/06/26 Javascript
vue form 表单提交后刷新页面的方法
2018/09/04 Javascript
koa源码中promise的解读
2018/11/13 Javascript
vue组件之间的数据传递方法详解
2019/04/19 Javascript
小程序如何构建骨架屏
2019/05/29 Javascript
react quill中图片上传由默认转成base64改成上传到服务器的方法
2019/10/30 Javascript
详解vue中v-model和v-bind绑定数据的异同
2020/08/10 Javascript
Python更新数据库脚本两种方法及对比介绍
2017/07/27 Python
Python数据处理numpy.median的实例讲解
2018/04/02 Python
浅谈Pandas中map, applymap and apply的区别
2018/04/10 Python
详解TensorFlow查看ckpt中变量的几种方法
2018/06/19 Python
python使用pipeline批量读写redis的方法
2019/02/18 Python
python爬虫开发之使用python爬虫库requests,urllib与今日头条搜索功能爬取搜索内容实例
2020/03/10 Python
Python控制鼠标键盘代码实例
2020/12/08 Python
HTML5制作酷炫音频播放器插件图文教程
2014/12/30 HTML / CSS
深入理解HTML5定时器requestAnimationFrame的使用
2018/12/12 HTML / CSS
手机促销活动方案
2014/02/05 职场文书
高二物理教学反思
2014/02/08 职场文书
个人借款担保书
2014/04/02 职场文书
2014年党支部承诺书
2014/05/30 职场文书
党员个人剖析材料
2014/09/30 职场文书
2015年高校就业工作总结
2015/05/04 职场文书