vue生成token保存在客戶端localStorage中的方法
前面我們已經(jīng)了解了可以通過localStorage在客戶端(瀏覽器)保存數(shù)據(jù)。
我們后端有這樣一個接口:
http://localhost/yiiserver/web/index.php/token?client_appid=aaa&client_appkey=bbb
其實就向clients(理解為用戶表即可)里面去生成一個token

這里的client_appid 就相當于用戶名,client_appkey 就相當于密碼。
這樣后端認證之后會生成一個access-token,我們需要把這個access-token 保存在客戶端。
注意:我們前端一般部署在另外的服務器上,會跨域,后端要處理跨域的問題,在PHP中可以寫上如下代碼:
//指定允許其他域名訪問
header("Access-Control-Allow-Origin: *");
header("Access-Control-Allow-Methods: GET,POST");
header('Access-Control-Allow-Headers: X-Requested-With,content-type,if-modified-since');
前端的套路
注意,我們項目既然早已用上了VueX,那么我肯定就要在Store(vuex里的概念)里面來創(chuàng)建一個module。

我們新建了一個UsersModule.js 來處理用戶登錄的業(yè)務,注意不要忘記在入口文件users-index.js 中引入。如果我們的『會員后臺』也需要用戶相關數(shù)據(jù),也要引入。
在users-index.js 里修改:
//引入模塊
import ResModule from './../Store/modules/ResModules';
import UsersModule from "./../Store/modules/UsersModule";
const vuex_config = new Vuex.Store({
modules: {
res:ResModule,
users:UsersModule
}
});
1、UsersModule.js
import Vue from "vue";
export default {
state:{
currentUser:{
get UserName(){
return localStorage.getItem("currentUser_name");
},
get UserToken(){
return localStorage.getItem("currentUser_token");
}
}
},
mutations:{
setUser(state,{user_name,user_token}){
// 在這里把用戶名和token保存起來
localStorage.setItem("currentUser_name",user_name);
localStorage.setItem("currentUser_token",user_token);
}
},
actions:{
userLogin(context,{user_name,user_pass}){
// 發(fā)送get請求做權限認證(真實開發(fā)建議用post的方式)
let url = "http://localhost/yiiserver/web/index.php/token?client_appid="+user_name+"&client_appkey="+user_pass;
console.log(url);
Vue.http.get(url)
.then((res)=>{
if (res!=null && res.body!=undefined && "access-token" in res.body){
var token = res.body["access-token"];
if (token != ""){
// 后端API驗證通過
// 調(diào)用上面mutations里定義的方法
context.commit("setUser",{"user_name":user_name,"user_token":token});
}
}else{
alert("用戶名密碼錯誤");
}
},(res)=>{
alert("請求失敗進入這里")
});
}
}
}
actions部分:我們寫了一個userLogin()方法,來發(fā)送http請求后端服務器,請求成功返回的數(shù)據(jù)調(diào)用在mutations部分定義的setUser()方法保存到客戶端。
注意:actions里的userLogin()方法,是供在用戶登錄頁調(diào)用的,也就是userslogin.vue里。
所以來到userlogin.vue,修改如下代碼:
我們來測試一下,有沒有成功保存到客戶端的localStorage 中:
methods:{
login(){
// 這個驗證是element-ui框架提供的方法
this.$refs["users"].validate(function (flag) {
if(flag){
/*localStorage.setItem("currentUser",this.UserModel.user_name);
alert("用戶登錄成功");*/
this.$store.dispatch("userLogin",{"user_name":this.UserModel.user_name,"user_pass":this.UserModel.user_pass})
}else{
alert("用戶名密碼必填");
}
}.bind(this));
}
}

2、如果我們的會員后臺
也需要獲取用戶的登錄信息,比如用戶名。來顯示到導航欄上。
首先是應該在會員后臺模塊的入口文件member-index.js中:
//引入Module
import ResModule from './../Store/modules/ResModules';
import UsersMoule from "./../Store/modules/UsersModule";
const vuex_config = new Vuex.Store({
modules: {
res:ResModule,
users:UsersMoule
}
});
然后我們就可以在,比如導航欄組件navbar.vue中:
<a href="##" rel="external nofollow" >{{this.$store.state.users.currentUser.UserName}}</a>
通過這樣的方式,訪問users里的屬性。

以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關文章
基于vue v-for 多層循環(huán)嵌套獲取行數(shù)的方法
今天小編就為大家分享一篇基于vue v-for 多層循環(huán)嵌套獲取行數(shù)的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-09-09
解決VUE項目localhost端口服務器拒絕連接,只能用127.0.0.1的問題
這篇文章主要介紹了解決VUE項目localhost端口服務器拒絕連接,只能用127.0.0.1的問題2020-08-08
vue父組件給子組件的組件傳值provide inject的方法
在本篇文章里小編給大家整理的是一篇關于vue父組件給子組件的組件傳值provide inject的方法,需要的朋友們學習下。2019-10-10
python虛擬環(huán)境 virtualenv的簡單使用
virtualenv是一個創(chuàng)建隔絕的Python環(huán)境的工具。這篇文章主要介紹了python虛擬環(huán)境 virtualenv的簡單使用,本文給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下2020-01-01
vue使用axios獲取不到響應頭Content-Disposition的問題及解決
這篇文章主要介紹了vue使用axios獲取不到響應頭Content-Disposition的問題及解決,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-06-06

