在vue中獲取token,并將token寫(xiě)進(jìn)header的方法
需要準(zhǔn)備的東西:Vue+axios+Vuex+Vue-router
1.在login.vue中通過(guò)發(fā)送http請(qǐng)求獲取token
//根據(jù)api接口獲取token var url = this.HOST + "/session"; this.$axios.post(url, { username: this.loginForm.username, password: this.loginForm.pass }).then(res => { // console.log(res.data); this.$message.success('登錄成功'); let data = res.data; //根據(jù)store中set_token方法將token保存至localStorage/sessionStorage中,data["Authentication-Token"],獲取token的value值 this.$store.commit('set_token', data["Authentication-Token"]); if (store.state.token) { this.$router.push('/') console.log(store.state.token) } else { this.$router.replace('/login'); } }).catch(error => { // this.$message.error(error.status) this.loading = false this.loginBtn = "登錄" this.$message.error('賬號(hào)或密碼錯(cuò)誤'); // console.log(error) })
2.在store.js中對(duì)token狀態(tài)進(jìn)行監(jiān)管
import Vue from 'vue' import Vuex from 'vuex' Vue.use(Vuex) export default new Vuex.Store({ state:{ token:'' }, mutations:{ set_token(state, token) { state.token = token sessionStorage.token = token }, del_token(state) { state.token = '' sessionStorage.removeItem('token') } } })
3.在router/index.js中
// 頁(yè)面刷新時(shí),重新賦值token if (sessionStorage.getItem('token')) { store.commit('set_token', sessionStorage.getItem('token')) } const router = new Router({ mode: "history", routes }); router.beforeEach((to, from, next) => { if (to.matched.some(r => r.meta.requireAuth)) { //這里的requireAuth為路由中定義的 meta:{requireAuth:true},意思為:該路由添加該字段,表示進(jìn)入該路由需要登陸的 if (store.state.token) { next(); } else { next({ path: '/login', query: {redirect: to.fullPath} }) } } else { next(); } })
4.在main.js中定義全局默認(rèn)配置:
Axios.defaults.headers.common['Authentication-Token'] = store.state.token;
5.在src/main.js添加攔截器
// 添加請(qǐng)求攔截器 Axios.interceptors.request.use(config => { // 在發(fā)送請(qǐng)求之前做些什么 //判斷是否存在token,如果存在將每個(gè)頁(yè)面header都添加token if(store.state.token){ config.headers.common['Authentication-Token']=store.state.token } return config; }, error => { // 對(duì)請(qǐng)求錯(cuò)誤做些什么 return Promise.reject(error); }); // http response 攔截器 Axios.interceptors.response.use( response => { return response; }, error => { if (error.response) { switch (error.response.status) { case 401: this.$store.commit('del_token'); router.replace({ path: '/login', query: {redirect: router.currentRoute.fullPath}//登錄成功后跳入瀏覽的當(dāng)前頁(yè)面 }) } } return Promise.reject(error.response.data) });
以上這篇在vue中獲取token,并將token寫(xiě)進(jìn)header的方法就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
vue-preview動(dòng)態(tài)獲取圖片寬高并增加旋轉(zhuǎn)功能的實(shí)現(xiàn)
這篇文章主要介紹了vue-preview動(dòng)態(tài)獲取圖片寬高并增加旋轉(zhuǎn)功能的實(shí)現(xiàn),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-07-07從源碼角度來(lái)回答keep-alive組件的緩存原理
這篇文章主要介紹了從源碼角度來(lái)回答keep-alive組件的緩存原理,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2021-01-01詳解從Vue.js源碼看異步更新DOM策略及nextTick
本篇文章主要介紹了從Vue.js源碼看異步更新DOM策略及nextTick,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一2017-10-10vue前端通過(guò)騰訊接口獲取用戶(hù)ip的全過(guò)程
今天在寫(xiě)項(xiàng)目掉接口的時(shí)候有一個(gè)接口需要到了用戶(hù)的ip地址,查了半天覺(jué)得這個(gè)方法不錯(cuò),下面這篇文章主要給大家介紹了關(guān)于vue前端通過(guò)騰訊接口獲取用戶(hù)ip的相關(guān)資料,需要的朋友可以參考下2022-12-12如何利用VUE監(jiān)聽(tīng)網(wǎng)頁(yè)關(guān)閉并執(zhí)行退出操作
這篇文章主要給大家介紹了關(guān)于如何利用VUE監(jiān)聽(tīng)網(wǎng)頁(yè)關(guān)閉并執(zhí)行退出操作的相關(guān)資料,因?yàn)轫?xiàng)目中需求,瀏覽器關(guān)閉時(shí)進(jìn)行一些操作處理,文中通過(guò)代碼示例介紹的非常詳細(xì),需要的朋友可以參考下2023-08-08解決vue build打包之后首頁(yè)白屏的問(wèn)題
下面小編就為大家分享一篇解決vue build打包之后首頁(yè)白屏的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-03-03vue render函數(shù)動(dòng)態(tài)加載img的src路徑操作
這篇文章主要介紹了vue render函數(shù)動(dòng)態(tài)加載img的src路徑操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-10-10vue如何實(shí)現(xiàn)多組關(guān)鍵詞對(duì)應(yīng)高亮顯示
這篇文章主要介紹了vue如何實(shí)現(xiàn)多組關(guān)鍵詞對(duì)應(yīng)高亮顯示問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-10-10