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 入门讲解1
Apr 15 Javascript
基于jQuery.Validate验证库知识点的详解
Apr 26 Javascript
javascript中的=等号个数问题两个跟三个有什么区别
Oct 23 Javascript
node.js学习总结之调式代码的方法
Jun 25 Javascript
javascript上下方向键控制表格行选中并高亮显示的方法
Feb 13 Javascript
JavaScript中用于四舍五入的Math.round()方法讲解
Jun 15 Javascript
Restify中接入Socket.io报Error:Can’t set headers的错误解决
Mar 28 Javascript
使用JavaScript开发跨平台的桌面应用详解
Jul 27 Javascript
解决IE11 vue +webpack 项目中数据更新后页面没有刷新的问题
Sep 25 Javascript
详解Vue.js和layui日期控件冲突问题解决办法
Jul 25 Javascript
浅谈Vue中render中的h箭头函数
Nov 07 Javascript
vue路由拦截器和请求拦截器知识点总结
Nov 08 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
session在php5.3中的变化 session_is_registered() is deprecated in
2013/11/12 PHP
php判断表是否存在的方法
2015/06/18 PHP
Laravel框架中Blade模板的用法示例
2017/08/30 PHP
PHP实现字符串大小写转函数的功能实例
2019/02/06 PHP
Laravel监听数据库访问,打印SQL的例子
2019/10/24 PHP
PHP如何通过带尾指针的链表实现'队列'
2020/10/22 PHP
用javascript实现给出的盒子的序列是否可连为一矩型
2007/08/30 Javascript
Jquery实现动态切换图片的方法
2015/05/18 Javascript
AngularJS实现分页显示数据库信息
2016/07/01 Javascript
JavaScript 网页中实现一个计算当年还剩多少时间的倒数计时程序
2017/01/25 Javascript
bootstrap Validator 模态框、jsp、表单验证 Ajax提交功能
2017/02/17 Javascript
Vue非父子组件通信详解
2017/06/12 Javascript
基于Bootstrap下拉框插件bootstrap-select使用方法详解
2018/08/07 Javascript
JavaScript时间日期操作实例小结【5个示例】
2018/12/22 Javascript
使用js在layui中实现上传图片压缩
2019/06/18 Javascript
详解elementui之el-image-viewer(图片查看器)
2019/08/30 Javascript
写给新手同学的vuex快速上手指北小结
2020/04/14 Javascript
JavaScript indexOf()原理及使用方法详解
2020/07/09 Javascript
[40:19]完美世界DOTA2联赛PWL S3 Rebirth vs CPG 第二场 12.18
2020/12/19 DOTA
Python实现同时兼容老版和新版Socket协议的一个简单WebSocket服务器
2014/06/04 Python
python制作爬虫爬取京东商品评论教程
2016/12/16 Python
Python列表推导式与生成器表达式用法示例
2018/02/08 Python
windows下添加Python环境变量的方法汇总
2018/05/14 Python
python实现批量修改图片格式和尺寸
2018/06/07 Python
python cs架构实现简单文件传输
2020/03/20 Python
python将秒数转化为时间格式的实例
2018/09/16 Python
Python使用gRPC传输协议教程
2018/10/16 Python
解决python 无法加载downsample模型的问题
2018/10/25 Python
详解numpy.meshgrid()方法使用
2019/08/01 Python
使用Keras 实现查看model weights .h5 文件的内容
2020/06/09 Python
HTML5 中新的全局属性(整理)
2013/07/31 HTML / CSS
ETO男装官方网店:ETO Jeans
2019/02/28 全球购物
个人查摆问题整改措施
2014/10/04 职场文书
考试作弊检讨书
2015/01/27 职场文书
会议主持词通用版
2019/04/02 职场文书
webpack的移动端适配方案小结
2021/07/25 Javascript