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玩转游戏物理(一)运动学模拟与粒子系统
Jun 19 Javascript
javascript中的对象创建 实例附注释
Feb 08 Javascript
JS调用页面表格导出excel示例代码
Mar 18 Javascript
详解JavaScript语法对{}处理的坑爹之处
Jun 05 Javascript
Angular外部使用js调用Angular控制器中的函数方法或变量用法示例
Aug 05 Javascript
轻松掌握JavaScript状态模式
Sep 07 Javascript
vue配置nprogress实现页面顶部进度条
Sep 21 Javascript
Vue快速实现通用表单验证的示例代码
Jan 09 Javascript
JavaScript鼠标拖拽事件详解
Apr 03 Javascript
利用Vue的v-for和v-bind实现列表颜色切换
Jul 17 Javascript
基于vue.js仿淘宝收货地址并设置默认地址的案例分析
Aug 20 Javascript
Vue自定义组件双向绑定实现原理及方法详解
Sep 03 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
phpMyAdmin 链接表的附加功能尚未激活的问题
2010/08/01 PHP
9段PHP实用功能的代码推荐
2014/10/14 PHP
PHP SPL标准库之文件操作(SplFileInfo和SplFileObject)实例
2015/05/11 PHP
php实现评论回复删除功能
2017/05/23 PHP
PHP ADODB实现事务处理功能示例
2018/05/25 PHP
laravel实现图片上传预览,及编辑时可更换图片,并实时变化的例子
2019/11/14 PHP
Javascript笔记一 js以及json基础使用说明
2010/05/22 Javascript
node.js中的fs.openSync方法使用说明
2014/12/17 Javascript
js实现可兼容IE、FF、Chrome、Opera及Safari的音乐播放器
2015/02/11 Javascript
浅谈Javascript的静态属性和原型属性
2015/05/07 Javascript
js实现类似MSN提示的页面效果代码分享
2015/08/24 Javascript
原生js和jQuery实现淡入淡出轮播效果
2015/12/25 Javascript
jquery之别踩白块游戏的简单实现
2016/07/25 Javascript
Vue.js表单控件实践
2016/10/27 Javascript
node.js遍历目录的方法示例
2018/08/01 Javascript
JavaScript自动生成 年月范围 选择功能完整示例【基于jQuery插件】
2019/09/03 jQuery
NodeJS实现一个聊天室功能
2019/11/25 NodeJs
JS script脚本中async和defer区别详解
2020/06/24 Javascript
JS数组转字符串实现方法解析
2020/09/04 Javascript
React倒计时功能实现代码——解耦通用
2020/09/18 Javascript
[01:16]2014DOTA2 TI专访C9战队EE:中国五强中会占三席
2014/07/10 DOTA
Python脚本实现12306火车票查询系统
2016/09/30 Python
Python3连接SQLServer、Oracle、MySql的方法
2018/06/28 Python
uwsgi+nginx部署Django项目操作示例
2018/12/04 Python
Django中密码的加密、验密、解密操作
2019/12/19 Python
python路径的写法及目录的获取方式
2019/12/26 Python
前端面试必备之html5的新特性
2017/09/05 HTML / CSS
Herschel美国官网:背包、手提袋及配件
2020/03/10 全球购物
Linux面试题LINUX系统类
2015/11/25 面试题
保安员岗位职责
2013/11/17 职场文书
工程项目经理岗位职责
2013/12/15 职场文书
超市促销活动总结
2014/07/01 职场文书
秋季运动会开幕词
2015/01/28 职场文书
运动会100米广播稿
2015/08/19 职场文书
小程序实现文字循环滚动动画
2021/06/14 Javascript
不同品牌、不同型号对讲机如何互相通联
2022/02/18 无线电