Cookie
裏,下次用戶再向服務端發送請求時能夠帶着這個Cookie
,這樣服務端會驗證該Cookie
裏的信息,若是找到對應的記錄,說明用戶經過了身份驗證,就把用戶請求的數據返回給客戶端Session
,須要再服務端按期清理過時的Session
Token
,再把這個Token
發送給客戶端Token
之後能夠把它存儲起來,好比放在Cookie
裏或者Local Storage
裏Token
Token
,若是驗證成功,就向客戶端返回請求的數據token
存入本地cookie
中,能夠保證每次刷新時用戶登陸狀態不丟失token
,還能夠獲取到用戶的其餘信息點擊`handleLogin`觸發`vuex`中`actions`的`Login`派發行爲
複製代碼
handleLogin() {
this.$store
.dispatch('Login', this.loginForm)
.then(() => {
this.$router.push({ path: '/' });
})
.catch(() => {
})
}
複製代碼
而後回到vuex
,這裏的store.js
改爲store
文件夾,分模塊管理vuex
javascript
// 文件夾結構
|-- store
|-- modules
|-- getters.js
|-- index.js
複製代碼
咱們劃分出,app, user 兩個模塊,在 user 裏控制用戶的登陸信息,app 中存儲應用的狀態,如全局loading
或者控制第三方組件的全局大小,如element-ui
中的全局組件size
前端
// index.vue
import Vue from 'vue'
import Vuex from 'vuex'
import user from './modules/user'
import getters from './getters'
Vue.use(Vuex)
const store = new Vuex.Store({
modules: {
user
},
getters
})
export default store
複製代碼
user.js
中存儲了登陸事件所需的事件和數據,handleLogin
事件觸發的是modules
中user
模塊的actions
,這裏user.js
中的具體方法和state
數據,均是封裝過的vue
utils/auth.js
中封裝設置cookie
的方法// 導入 Cookies
import Cookies from 'js-cookie'
// 設置 cookie name
const TokenKey = 'Admin-Token'
// 獲取 Admin-Token 的 cookie
export function getToken() {
return Cookies.get(TokenKey);
}
// setToken
export function setToken(token) {
return Cookies.set(TokenKey, token);
}
// 移除 token
export function removeToken() {
return Cookies.remove(TokenKey)
}
複製代碼
utils/request
中封裝axios
請求設置import axios from 'axios'
import store from '../store'
import { getToken } from '@/utils/auth'
const service = axios.create({
baseURL: 'http://193.112.153.155:3001',
timeout: 5000 // 請求超時時間
})
export default service
複製代碼
import request from '@/utils/request'
export function login(username, password) {
return request({
url: '/user/login',
method: 'post',
data: {
username,
password
}
})
}
export function getInfo(token) {
return request({
url: '/user/info',
method: 'get',
params: { token }
})
}
export function logout() {
return request({
url: '/user/logout',
method: 'post'
})
}
複製代碼
store
import { login, logout, getInfo } from '@/api/login'
import { getToken, setToken, removeToken } from '@/utils/auth'
const user = {
state: {
token: getToken(),
name: '',
avatar: '',
roles: []
},
mutations: {
SET_TOKEN: (state, token) => {
state.token = token
},
SET_NAME: (state, name) => {
state.name = name
},
SET_AVATAR: (state, avatar) => {
state.avatar = avatar
},
SET_ROLES: (state, roles) => {
state.roles = roles
}
},
actions: {
// 登陸
Login({ commit }, userInfo) {
const username = userInfo.username.trim()
return new Promise((resolve, reject) => {
login(username, userInfo.password).then(response => {
const data = response.data;
setToken(data.token)
commit('SET_TOKEN', data.token);
resolve()
}).catch(error => {
reject(error)
})
})
},
// 獲取用戶信息
GetInfo({ commit, state }) {
return new Promise((resolve, reject) => {
getInfo(state.token).then(response => {
const data = response.data
if (data.roles && data.roles.length > 0) { // 驗證返回的roles是不是一個非空數組
commit('SET_ROLES', data.roles)
} else {
reject('getInfo: roles must be a non-null array !')
}
commit('SET_NAME', data.name)
commit('SET_AVATAR', data.avatar)
resolve(response)
}).catch(error => {
reject(error)
})
})
},
// 登出
LogOut({ commit, state }) {
return new Promise((resolve, reject) => {
logout(state.token).then(() => {
commit('SET_TOKEN', '')
commit('SET_ROLES', [])
removeToken()
resolve()
}).catch(error => {
reject(error)
})
})
},
// 前端 登出
FedLogOut({ commit }) {
return new Promise(resolve => {
commit('SET_TOKEN', '')
removeToken()
resolve()
})
}
}
}
export default user
複製代碼
本文僅供我的學習總結使用 參考:java
手摸手,帶你用vue擼後臺 系列二(登陸權限篇) )vuex