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 相关文章推荐
JQuery中dataGrid设置行的高度示例代码
Jan 03 Javascript
jquery退出each循环的写法
Feb 26 Javascript
jQuery表格列宽可拖拽改变且兼容firfox
Sep 03 Javascript
jQuery中parents()和parent()的区别分析
Oct 28 Javascript
深入理解JavaScript系列(38):设计模式之职责链模式详解
Mar 04 Javascript
JS显示表格内指定行html代码的方法
Mar 31 Javascript
JS+CSS实现的简单折叠展开多级菜单效果
Sep 12 Javascript
JavaScript实现的Tween算法及缓冲特效实例代码
Nov 03 Javascript
JavaScript的ExtJS框架中表格的编写教程
May 21 Javascript
Web前端框架bootstrap实战【第一次接触使用】
Dec 28 Javascript
vuejs选中当前样式active的实例
Aug 22 Javascript
vue实现鼠标移入移出事件代码实例
Mar 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
php下图片文字混合水印与缩略图实现代码
2009/12/11 PHP
php结合ajax实现赞、顶、踩功能实例
2014/05/12 PHP
php实现插入排序
2015/03/29 PHP
Zend Framework教程之请求对象的封装Zend_Controller_Request实例详解
2016/03/07 PHP
PHP7.1新功能之Nullable Type用法分析
2016/09/26 PHP
Yii1.1中通过Sql查询进行的分页操作方法
2017/03/16 PHP
Laravel 5.5 异常处理 &amp; 错误日志的解决
2019/10/17 PHP
Ext JS添加子组件的误区探讨
2013/06/28 Javascript
node.js中的fs.exists方法使用说明
2014/12/17 Javascript
详解javascript的变量与标识符
2016/01/04 Javascript
使用jQuery判断浏览器滚动条位置的方法
2016/05/30 Javascript
React组件refs的使用详解
2018/02/09 Javascript
解决vue 打包发布去#和页面空白的问题
2018/09/04 Javascript
浅谈微信页面入口文件被缓存解决方案
2018/09/29 Javascript
node微信开发之获取access_token+自定义菜单
2019/03/17 Javascript
element表格翻页第2页从1开始编号(后端从0开始分页)
2019/12/10 Javascript
javascript设计模式 ? 装饰模式原理与应用实例分析
2020/04/14 Javascript
[14:51]DOTA2 HEROS教学视频教你分分钟做大人-卓尔游侠
2014/06/13 DOTA
flask + pymysql操作Mysql数据库的实例
2017/11/13 Python
python利用socketserver实现并发套接字功能
2018/01/26 Python
python列表的增删改查实例代码
2018/01/30 Python
linux中如何使用python3获取ip地址
2019/07/15 Python
python print 格式化输出,动态指定长度的实现
2020/04/12 Python
Python 操作 MySQL数据库
2020/09/18 Python
亚洲最大旅游体验平台:KKday
2017/10/21 全球购物
个人作风建设总结
2014/10/23 职场文书
毕业论文致谢部分怎么写
2015/05/14 职场文书
党支部考察鉴定意见
2015/06/02 职场文书
鉴史问廉观后感
2015/06/10 职场文书
诚实守信主题班会
2015/08/13 职场文书
2016年情人节问候语
2015/11/11 职场文书
导游词之吉林吉塔
2019/11/11 职场文书
redis 存储对象的方法对比分析
2021/08/02 Redis
MySQL七大JOIN的具体使用
2022/02/28 MySQL
Oracle配置dblink访问PostgreSQL的操作方法
2022/03/21 PostgreSQL
服务器间如何实现文件共享
2022/05/20 Servers