欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

vue項目中js-cookie的使用存儲token操作

 更新時間:2020年11月13日 15:35:53   作者:情非得已小猿猿  
這篇文章主要介紹了vue項目中js-cookie的使用存儲token操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧

1、安裝js-cookie

# npm install js-cookie --save

# yarn add js-cookie

2、引用(需要的文件)

import Cookies from 'js-cookie' 
const TokenKey = 'Admin-Token' 
export function getToken() {
 return Cookies.get(TokenKey)
}
 
export function setToken(tcuncuoken) {
 return Cookies.set(TokenKey, token)
}
 
export function removeToken() {
 return Cookies.remove(TokenKey)
}

3、瀏覽器cookie

4、 也可以存儲其他

const user = {
 name: 'lia',
 age: 18
}
Cookies.set('user', user)
const liaUser = JSON.parse(Cookies.get('user'))

補充知識:vue 實現(xiàn)記住密碼功能,用戶信息在客戶端加密存儲

效果圖:

功能詳解:用戶登錄時,勾選記住密碼,系統(tǒng)會將登錄信息存入瀏覽器cookie中,下次登錄時系統(tǒng)會自動將信息回寫在輸入框中(默認(rèn)設(shè)置保存時間為3天,此處需要將密碼進行加密處理,以提高安全性)

1.定義頁面元素,v-model綁定變量

2.

3.引入vue的加密組件 CryptoJS,執(zhí)行這條命令,系統(tǒng)會自動安裝

npm install crypto-js

安裝成功后,還需在登錄頁面引入組件

4.定義操作cookie的三個方法,后面需要用到,代碼我貼出來

 /************* Cookie start ***************/
   clearCookie(cookieName) {
    var exp = new Date();
    exp.setTime(exp.getTime() - 1);
    var cval = this.getCookie(cookieName);
    if (cval != null) {
     document.cookie = cookieName + "=" + cval + ";expires=" + exp.toGMTString();
    }
   },
 
   setCookie(cookieName, value, expiremMinutes) {
    var exdate = new Date();
    exdate.setTime(exdate.getTime() + expiremMinutes * 60 * 1000);
    document.cookie = cookieName + "=" + escape(value) + ((expiremMinutes == null) ? "" : ";expires=" + exdate.toGMTString());
   },
 
   getCookie(cookieName) {
    if (document.cookie.length > 0) {
     var c_start = document.cookie.indexOf(cookieName + "=");
     if (c_start != -1) {
      c_start = c_start + cookieName.length + 1;
      var c_end = document.cookie.indexOf(";", c_start);
      if (c_end == -1)
       c_end = document.cookie.length
      return unescape(document.cookie.substring(c_start, c_end))
     }
    }
    return ""
   },
   /*************Cookie end***************/

5.在登錄方法中判斷記住密碼是否有被勾選,如果有,則需要將賬號密碼信息存入cookie中,沒有,則調(diào)用上面的方法清除cookie信息,關(guān)鍵步驟我已標(biāo)記,登錄方法在下面:

/************* 登錄 start ***************/
   signIn() {
    let _this = this;
    //判斷是密碼登錄還是短信登錄
    if (_this.indexd == 0) {
     _this.$refs['ruleForm'].validate((valid) => {
      if (valid) {
 
       //定義要存入cookie的對象
       var accountInfo = ""; 
       //拿到輸入框中的密碼,使用AES加密
       var pwd = _this.form.pwd;
       var newPwd = CryptoJS.AES.encrypt(pwd,'secret key 123'); 
 
       //若勾選記住密碼
       if (_this.checked == true) {
        console.log("選擇記住密碼,checked == true");
        accountInfo = _this.form.name + "&" + newPwd; //將加密后的密碼存入cookie對象中
        _this.setCookie('accountInfo',accountInfo,1440*3); //傳入賬號名,密碼,和保存天數(shù)3個參數(shù)(3天)
       }else {
        console.log("清空Cookie");
        _this.clearCookie('accountInfo'); //清空Cookie
       }
 
 
       let params = {
        "username": _this.form.name,
        "password": _this.form.pwd,
        "vCode": _this.form.imgCode,
        "loginToken": _this.loginToken,
       };
       post('/login/login', params).then(function (response) {
        if (response.data.code == "20000") {
         sessionStorage.setItem("v-token", response.data.data.token);
         sessionStorage.setItem("v-menu", JSON.stringify(response.data.data.routers));
         sessionStorage.setItem("v-user", JSON.stringify(response.data.data.currentUser));
         //_this.makeRouters(response.data.data.routers);
         _this.$message({
          message: '登錄成功',
          type: 'success'
         });
         _this.clearCookie("login_token");//清除token
         //平臺
         if (response.data.data.currentUser.type == 0) {
          //平臺
          _this.$router.push('/index');
         } else if (response.data.data.currentUser.type == 1 || response.data.data.currentUser.type == 3 || response.data.data.currentUser.type == 2) {
          //渠道商
          _this.$router.push('/operate');
         } else {
          //證券商
          _this.$router.push('/AoInformationManagement')
         }
 
        } else if (response.data.code == "50000") {
         _this.$message.warning(response.data.msg);
         _this.changeCode();
        }
       }).catch(function (err) {
        _this.$message.error(err);
        _this.changeCode();
       })
      }
     });
    } 
   }

5.選擇記住密碼,登錄系統(tǒng)后,可以在調(diào)試模式中查看cookie信息,如圖:

6.退出系統(tǒng)后,需要判斷cookie有無賬號信息,如果有,則進行回寫,下面是我的方法:

在鉤子方法中調(diào)用下面的loadAccountInfo回寫方法

//預(yù)讀取cookie中用戶信息
   loadAccountInfo(){
    let self = this;
    //admin%26U2FsdGVkX1+/ZtAGWFVi37gNwA7TUZmQM+yazInCPxs%3D
    let accountInfo = self.getCookie('accountInfo');
 
    //如果cookie里沒有賬號信息
    if(Boolean(accountInfo) == false){
     console.log('cookie中沒有檢測到用戶賬號信息!');
     return false;
    } else{
     //如果cookie里有賬號信息
     console.log('cookie中檢測到賬號信息!現(xiàn)在開始預(yù)填寫!');
     let userName = "";
     let passWord = "";
     let index = accountInfo.indexOf("&");
 
     userName = accountInfo.substring(0,index);
     passWord = accountInfo.substring(index+1);  //拿到加密后的密碼
     //解密
     var bytes = CryptoJS.AES.decrypt(passWord.toString(),'secret key 123');
     //拿到解密后的密碼(登錄時輸入的密碼)
     var newpassWord = bytes.toString(CryptoJS.enc.Utf8);
 
     self.form.name = userName;
     self.form.pwd = newpassWord;
     self.checked = true;
    }
   },

7.最后效果就是這樣

以上這篇vue項目中js-cookie的使用存儲token操作就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • 第一次使用webstrom簡單創(chuàng)建vue項目的一些報錯實戰(zhàn)記錄

    第一次使用webstrom簡單創(chuàng)建vue項目的一些報錯實戰(zhàn)記錄

    在使用webstorm新建vue項目時常會遇到一些報錯,特別是新手第一次運行項目,這篇文章主要給大家介紹了關(guān)于第一次使用webstrom簡單創(chuàng)建vue項目的一些報錯實戰(zhàn)記錄,需要的朋友可以參考下
    2023-02-02
  • 淺談VUE單頁應(yīng)用首屏加載速度優(yōu)化方案

    淺談VUE單頁應(yīng)用首屏加載速度優(yōu)化方案

    這篇文章主要介紹了淺談VUE單頁應(yīng)用首屏加載速度優(yōu)化方案,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-08-08
  • vue路由組件路徑如何用變量形式動態(tài)引入

    vue路由組件路徑如何用變量形式動態(tài)引入

    這篇文章主要介紹了vue路由組件路徑如何用變量形式動態(tài)引入問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-06-06
  • Element-ui DatePicker顯示周數(shù)的方法示例

    Element-ui DatePicker顯示周數(shù)的方法示例

    這篇文章主要介紹了Element-ui DatePicker顯示周數(shù)的方法示例,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-07-07
  • Vue項目分包打包配置(包含dev)完整過程

    Vue項目分包打包配置(包含dev)完整過程

    最近接到一個需求,公司需要對vue項目實現(xiàn)線上打包,下面這篇文章主要給大家介紹了關(guān)于Vue項目分包打包配置(包含dev)的相關(guān)資料,文中通過實例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2023-06-06
  • 詳解Vue如何實現(xiàn)字母驗證碼

    詳解Vue如何實現(xiàn)字母驗證碼

    這篇文章主要為大家介紹了Vue如何實現(xiàn)字母驗證碼詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-05-05
  • Vue TypeScript使用eval函數(shù)遇到的問題

    Vue TypeScript使用eval函數(shù)遇到的問題

    近幾年前端對 TypeScript的呼聲越來越高,Typescript也成為了前端必備的技能。TypeScript是JS類型的超集,并支持了泛型、類型、命名空間、枚舉等特性,彌補了 JS 在大型應(yīng)用開發(fā)中的不足
    2023-01-01
  • Vue組件封裝方案實現(xiàn)淺析

    Vue組件封裝方案實現(xiàn)淺析

    這篇文章主要介紹了Vue組件封裝方案實現(xiàn),我們將從分析組件封裝的優(yōu)勢開始,然后依次介紹 vue.js 的基本概念,以及如何創(chuàng)建、封裝和使用自定義組件
    2023-03-03
  • vue.js父子組件傳參的原理與實現(xiàn)方法

    vue.js父子組件傳參的原理與實現(xiàn)方法

    這篇文章主要介紹了vue.js父子組件傳參的原理與實現(xiàn)方法,結(jié)合實例形式分析了vue.js父子組件傳參的基本原理、實現(xiàn)方法與相關(guān)操作注意事項,需要的朋友可以參考下
    2023-04-04
  • 詳解vue-router 命名路由和命名視圖

    詳解vue-router 命名路由和命名視圖

    這篇文章主要介紹了詳解vue-router 命名路由和命名視圖,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-06-06

最新評論