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 相关文章推荐
用unescape反编码得出汉字示例
Apr 24 Javascript
jQuery子窗体取得父窗体元素的方法
May 11 Javascript
jQuery解析XML文件同时动态增加js文件的方法
Jun 01 Javascript
jQuery+css实现的切换图片功能代码
Jan 27 Javascript
PHP抓取HTTPS内容和错误处理的方法
Sep 30 Javascript
Vue.js表单控件实践
Oct 27 Javascript
JavaScript实现类似淘宝的购物车效果
Mar 16 Javascript
vue的基本用法与常见指令
Aug 15 Javascript
Webpack之tree-starking 解析
Sep 11 Javascript
JavaScript 高性能数组去重的方法
Sep 20 Javascript
对Layer弹窗使用及返回数据接收的实例详解
Sep 26 Javascript
了不起的11个JavaScript代码重构最佳实践小结
Jan 11 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
简单采集了yahoo的一些数据
2007/02/14 PHP
mysql_connect localhost和127.0.0.1的区别(网络层阐述)
2015/03/26 PHP
Ajax+Jpgraph实现的动态折线图功能示例
2019/02/11 PHP
php简单计算权重的方法示例【适合抽奖类应用】
2019/06/10 PHP
Javascript - HTML的request类
2007/01/09 Javascript
建议大家看下JavaScript重要知识更新
2007/07/08 Javascript
利用javascript实现一些常用软件的下载导航
2009/08/03 Javascript
javascript检测浏览器的缩放状态实现代码
2014/09/28 Javascript
js中hash和ico的关联分析
2015/02/05 Javascript
JS基于FileSystemObject创建一个指定路径的TXT文本文件
2015/08/05 Javascript
jQuery插件Validate实现自定义校验结果样式
2016/01/18 Javascript
Ionic2开发环境搭建教程
2020/08/20 Javascript
Vue2.0 组件传值通讯的示例代码
2017/08/01 Javascript
angular中ui calendar的一些使用心得(推荐)
2017/11/03 Javascript
使用Vue动态生成form表单的实例代码
2018/04/26 Javascript
js技巧之十几行的代码实现vue.watch代码
2018/06/09 Javascript
JS求1到任意数之间的所有质数的方法详解
2019/05/20 Javascript
详解使用WebPack搭建React开发环境
2019/08/06 Javascript
ES5和ES6中类的区别总结
2020/12/21 Javascript
vue+element UI实现树形表格
2020/12/29 Vue.js
Python实现提取谷歌音乐搜索结果的方法
2015/07/10 Python
Scrapy抓取京东商品、豆瓣电影及代码分享
2017/11/23 Python
Python OpenCV获取视频的方法
2018/02/28 Python
解决Python中list里的中文输出到html模板里的问题
2018/12/17 Python
Python使用Slider组件实现调整曲线参数功能示例
2019/09/06 Python
CSS3弹性盒模型flex box快速入门心得(必看篇)
2016/05/24 HTML / CSS
美国体育用品商店:Rally House(NCAA、NFL、MLB、NBA、NHL和MLS)
2018/01/03 全球购物
JustFab加拿大:女鞋、靴子、手袋和服装在线
2018/05/18 全球购物
软件测试笔试题
2012/10/25 面试题
大学应届毕业生个人求职信
2013/09/23 职场文书
银行贷款承诺书
2014/03/29 职场文书
六查六看个人剖析材料
2014/10/14 职场文书
人力资源部岗位职责
2015/02/11 职场文书
赢在执行观后感
2015/06/16 职场文书
2019年汽车租赁合同范本!
2019/08/12 职场文书
javascript实现计算器功能详解流程
2021/11/01 Javascript