Vue.js :登录状态localStorage、sessionStorage、cookie保存方式使用比较

  • Post author:
  • Post category:vue


Vue.js :登录状态localStorage、sessionStorage、cookie保存方式使用比较



一、localStorage


1.设置localStorage

if(!window.localStorage){
 	console.log("浏览器不支持localstorage");
}else{
    //主逻辑业务
    localStorage.setItem(name, val);
}


2.获取localStorage

if(!window.localStorage){
 	console.log("浏览器不支持localstorage");
}else{
    //主逻辑业务
    localStorage.getItem(name);
}


3.清除localStorage

if(!window.localStorage){
 	console.log("浏览器不支持localstorage");
}else{
    //主逻辑业务
    localStorage.removeItem(name);
}


4.使用心得


localStorage储存空间很大,可以达到5M;存储时间长,不去手动清除localStorage值会一直在,可以自己根据存储时间手动设定保留时间。例如:

  setToken(key, value) {
      let curtime = new Date().getTime(); // 获取当前时间 ,转换成JSON字符串序列 
      let valueDate = JSON.stringify({
          val: value,
          timer: curtime
      });
      localStorage.setItem(key, valueDate); 
  }
  getToken(key) {
      const exp = 86400*1000  // 设置保留时间为24小时    
      if(localStorage.getItem(key)) {
          var vals = localStorage.getItem(key); // 获取本地存储的值 
          var dataObj = JSON.parse(vals); // 将字符串转换成JSON对象
          // 如果(当前时间 - 存储的元素在创建时候设置的时间) > 过期时间 
          var isTimed = (new Date().getTime() - dataObj.timer) > exp;
          if(isTimed) {
              localStorage.removeItem(key);
              return null;
          } else {
               var newValue = dataObj.val;
          }
          return newValue;
      } else {
          return null;
      }
  }

关闭浏览器后重新打开值也一直在,但是我公司的产品要求是关闭浏览器后重新打开浏览器,登录状态要解除。我再vue使用中localStorage储存登录状态遇到的问题是前端js无法监测到浏览器关闭,网上

window.onbeforeunload

方法都试过都无法监测到浏览器关闭,或者是刷新页面也会触发,所以放弃这个localStorage方法的使用。



二、sessionStorage

使用大体上和localStorage一样


1.设置sessionStorage

if(!window.sessionStorage){
 	console.log("浏览器不支持sessionStorage");
}else{
    //主逻辑业务
    sessionStorage.setItem(name, val);
}


2.获取sessionStorage

if(!window.sessionStorage){
 	console.log("浏览器不支持sessionStorage");
}else{
    //主逻辑业务
    sessionStorage.getItem(name);
}


3.清除sessionStorage

if(!window.sessionStorage){
 	console.log("浏览器不支持sessionStorage");
}else{
    //主逻辑业务
    sessionStorage.removeItem(name);
}


4.使用心得


sessionStorage使用大体上和localStorage一样,sessionStorage有他唯一的特性就是,关闭浏览器后自动清除sessionStorage的值,似乎满足了关闭浏览器退出登录的需求,但是又出现了另个一个问题,同一个浏览器的不同窗口不能共享sessionStorage存的值,也就是每个窗口各有其sessionStorage值,这就导致了同一个浏览器客户端可以同时登录多个账号,不符合产品需求,所以也放弃这个使用。



三、cookie

我vue的项目中使用的是

‘js-cookie’

import Cookies from 'js-cookie'


1.设置cookie

Cookies.set(name, value);


2.获取cookie

Cookies.get(name)


3.清除cookie

Cookies.remove(name)


4.使用心得


cookie的expires可以配置cookie保留时间,不设置的保留时间的话关闭浏览器就会自动清除,刚好满足了我关闭浏览器退出登录的需求,我就选用了这种方式,如果要设置半个小时过期的话可以这样设置时间。例如:

setToken(key, value) {
   let curtime = new Date().getTime(); // 获取当前时间 ,转换成JSON字符串序列 
    let valueDate = JSON.stringify({
        val: value,
        timer: curtime
    });
    Cookies.set(key, valueDate);
 }
getToken(key) {
      const exp = 0.5*3600*1000   // 设置半小时
      if(Cookies.get(key) && Cookies.get(key) != undefined) {
          var vals = Cookies.get(key); // 获取本地存储的值 
          var dataObj = JSON.parse(vals); // 将字符串转换成JSON对象
          // 如果(当前时间 - 存储的元素在创建时候设置的时间) > 过期时间 
          var isTimed = (new Date().getTime() - dataObj.timer) > exp;
          if(isTimed) {
              Cookies.remove(key);
              return null;
          } else {
              var newValue = dataObj.val;
          }
          return newValue;
      } else {
          return null;
      }
  }

以上是一些做项目的心得体会,希望对大家有帮助。



版权声明:本文为qq_35483460原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。