Vue中的請求攔截器和響應(yīng)攔截器用法及說明
vue請求攔截器和響應(yīng)攔截器用法
今天就講一下什么是請求攔截器,和請求攔截器的作用,好了,多余的話我就不說了,馬上開始今天的講解
開始啦
請求攔截器
請求攔截器的作用是:
在請求發(fā)送前進行一些操作,例如在每個請求體里面加上token
,統(tǒng)一做了處理的,如果要更改也是非常的容易。
關(guān)于攔截
這里只說原理,前端的請求,最終離不開Ajax,像Vue的Vue-Resource
、Axios,都只是對Ajax進行了統(tǒng)一的封裝,它暴露出來的攔截器,其實就是寫了一個方法,把Ajax寫在這個方法里面(我們先說請求攔截器),在執(zhí)行的時候,先將請求時要添加給請求頭的那些數(shù)據(jù)(Token、后端要的加密的密碼)先執(zhí)行一遍,都賦值給一個變量,然后再統(tǒng)一傳給Ajax,接下來,就是執(zhí)行Ajax,這就是所謂的請求攔截器,其實就是先執(zhí)行要添加的數(shù)據(jù),然后再執(zhí)行Ajax,如果把這個添加數(shù)據(jù)的過程抽出來,就成了所謂的請求攔截器了
// 請求超時時間 axios.defaults.timeout = 120000 // 添加請求攔截器 axios.interceptors.request.use( config => { // 在發(fā)送請求之前做些什么 // 判斷是否存在token,如果存在將每個頁面header都添加token if (window.sessionStorage.getItem('DT')) { // 請求頭配置全局token config.headers.DT = window.sessionStorage.getItem('DT') } return config }, err => { // 對請求錯誤做些什么 Vue.prototype.$message.error('請求超時') return Promise.reject(err) } )
響應(yīng)攔截器
響應(yīng)攔截器的作用就是
在接收到響應(yīng)后再進行一些操作,例如在服務(wù)器返回登錄狀態(tài)失效的時候,需要重登錄,跳轉(zhuǎn)到登錄頁面,
響應(yīng)攔截器,就是是在請求結(jié)果的返回后的同時,先不直接導(dǎo)出,而是先對響應(yīng)碼等等的進行處理,處理好之后再導(dǎo)出給頁面,如果將這個對象響應(yīng)碼的處理過程抽出來,就成了所謂的響應(yīng)攔截器
代碼如下
// 響應(yīng)攔截器 axios.interceptors.response.use( response => { // res是響應(yīng)的結(jié)果 switch (response.data.code) { case 401: // 登錄失效 // 響應(yīng)成功的攔截 console.log('響應(yīng)攔截器:') // console.log(response.data) Vue.prototype.$message.error(response.data.message) sessionStorage.removeItem('DT') router.push('/login') break case 404: if (response.data.message !== null) { Vue.prototype.$message.error(response.data.message) } else { Vue.prototype.$message.error('未知錯誤') } break case 500: // 錯誤 if (response.data.message !== null) { Vue.prototype.$message.error(response.data.message) } else { Vue.prototype.$message.error('未知錯誤') } break default: return response } return response }, err => { if (err.response.data.message) { Vue.prototype.$message.error(err.response.data.message) return Promise.reject(err.response.data.message) // 返回接口返回的錯誤信息 } else { // 返回狀態(tài)碼不為200時候的錯誤處理 Vue.prototype.$message.error(err.toString()) return Promise.resolve(err) } } )
頁面中請求接口時:
// 用戶登錄提交 login() { // debugger this.$refs.loginFormRef.validate(async valid => { if (!valid) return if (valid) {const userInfo = { username: this.loginForm.username, password: this.loginForm.password } // 登錄之前去除token window.sessionStorage.removeItem('DT') const { data: res } = await this.$http.post('/system/login', userInfo) if (res.code !== 200) { this.initCaptcha() return } this.$message.success('登錄成功') window.sessionStorage.setItem('DT', res.result.token) this.$router.push('/main') } }) }
心得:
- 請求攔截器:其實就是先執(zhí)行要添加的數(shù)據(jù),然后再執(zhí)行Ajax,如果把這個添加數(shù)據(jù)的過程抽出來,就成了所謂的請求攔截器了
- 響應(yīng)攔截器:就是是在請求結(jié)果的返回后的同時,先不直接導(dǎo)出,而是先對響應(yīng)碼等等的進行處理,處理好之后再導(dǎo)出給頁面,如果將這個對象響應(yīng)碼的處理過程抽出來,就成了所謂的響應(yīng)攔截器
使用axios請求攔截器和響應(yīng)攔截器
在使用一些前后端會話時,需要在請求頭中攜帶一些特殊請求頭,這樣,就需要設(shè)置請求攔截器和響應(yīng)攔截器
開發(fā)項目時,由于后端使用了token令牌,登錄后在前端保存,然后每次請求都要攜帶token,將這些配置寫在main.js文件中是很亂的不易于閱讀,額外配置了axios請求配置模塊 這樣在以后對于請求響應(yīng)都能更好的配置而不會影響其他配置
如果不使用請求攔截,那么對每一條請求每一個狀態(tài)都要特殊處理,如果請求特殊狀態(tài)有數(shù)十個,每個頁面有很多請求,那么頁面會變得很長很臃腫,不好維護。
如何使用?
1.在utils文件夾中創(chuàng)建 一個request.js文件
文件內(nèi)容為(這里必須export這個配置后,才能被):
const service = axios.create({ timeout: 6000 //請求超時為6秒 }); //創(chuàng)建一個axios, 命名為service
2.先寫請求攔截器的邏輯代碼
//請求攔截器 service.interceptors.request.use(function(config) { // 處理請求之前的配置 //在請求頭headers加入token校驗 config.headers["token"] = "aded434088c7bcc595ec1c36c24aea1c" return config }, function(error) { // 請求失敗的處理 return Promise.reject(error); });
3.接著寫響應(yīng)攔截器的邏輯代碼
service.interceptors.response.use(function (response) { // 在接收響應(yīng)做些什么,例如跳轉(zhuǎn)到登錄頁 ...... return response; }, function (error) { // 對響應(yīng)錯誤做點什么 return Promise.reject(error); });
4.在統(tǒng)一管理的接口文件api.js使用
5.移除攔截器的方法
axios.interceptors.request.eject(service); //service為第一步中創(chuàng)建的axios
總結(jié)
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
vue中el-table和jsplumb實現(xiàn)連線功能
本文主要介紹了el-table和jsplumb實現(xiàn)連線功能,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-07-07Vue+Element實現(xiàn)表格編輯、刪除、以及新增行的最優(yōu)方法
這篇文章主要為大家詳細介紹了Vue+Element實現(xiàn)表格的編輯、刪除、以及新增行的最優(yōu)方法,具有一定的參考價值,感興趣的小伙伴們可以參考一下2019-05-05記一次用ts+vuecli4重構(gòu)項目的實現(xiàn)
這篇文章主要介紹了記一次用ts+vuecli4重構(gòu)項目的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-05-05