vue生成token保存在客戶端localStorage中的方法
前面我們已經了解了可以通過localStorage在客戶端(瀏覽器)保存數據。
我們后端有這樣一個接口:
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 中引入。如果我們的『會員后臺』也需要用戶相關數據,也要引入。
在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驗證通過
// 調用上面mutations里定義的方法
context.commit("setUser",{"user_name":user_name,"user_token":token});
}
}else{
alert("用戶名密碼錯誤");
}
},(res)=>{
alert("請求失敗進入這里")
});
}
}
}
actions部分:我們寫了一個userLogin()方法,來發(fā)送http請求后端服務器,請求成功返回的數據調用在mutations部分定義的setUser()方法保存到客戶端。
注意:actions里的userLogin()方法,是供在用戶登錄頁調用的,也就是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里的屬性。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

