這期內(nèi)容當(dāng)中小編將會(huì)給大家?guī)碛嘘P(guān)怎么在Vue中利用axios攔截請(qǐng)求,文章內(nèi)容豐富且以專業(yè)的角度為大家分析和敘述,閱讀完這篇文章希望大家可以有所收獲。
創(chuàng)新互聯(lián)-專業(yè)網(wǎng)站定制、快速模板網(wǎng)站建設(shè)、高性價(jià)比泗水網(wǎng)站開發(fā)、企業(yè)建站全套包干低至880元,成熟完善的模板庫(kù),直接使用。一站式泗水網(wǎng)站制作公司更省心,省錢,快速模板網(wǎng)站建設(shè)找我們,業(yè)務(wù)覆蓋泗水地區(qū)。費(fèi)用合理售后完善,10多年實(shí)體公司更值得信賴。項(xiàng)目使用的ui框架是iview
以下友好提示均使用iview ui的message提示組件,例如this.$Message.xxx
/api/request 僅僅只是例子接口,實(shí)際開發(fā)用后臺(tái)提供的接口。
code是后臺(tái)狀態(tài)碼,我這里也只是例子,不要問我為毛我的返回碼和你的怎么不一樣這樣的問題哈...這些都需要和后臺(tái)溝通約定的。
使用的請(qǐng)求頭是:axios.defaults.headers['Content-Type'] = 'application/x-www-form-urlencoded'
;至于為什么使用這個(gè)請(qǐng)求頭可以看看我的另外一篇文章關(guān)于axios會(huì)發(fā)送兩次請(qǐng)求,有個(gè)OPTIONS請(qǐng)求的問題
因?yàn)槭褂玫氖沁@個(gè)請(qǐng)求頭所以需要用qs模塊,不然后臺(tái)不認(rèn)這個(gè)數(shù)據(jù)。
不使用請(qǐng)求攔截
如果不使用請(qǐng)求攔截,也是可以的,但是會(huì)多了非常多的代碼,我們以登錄頁為例。
一個(gè)單純,沒有花里胡哨的頁面,|ω?)
//雙向數(shù)據(jù)綁定獲取值 let httpRequest = {}; httpRequest.loginName = this.loginName httpRequest.password= this.password this.$axios.post("/api/request", this.$qs.stringify(httpRequest)).then(data => { //特殊錯(cuò)誤處理,狀態(tài)為10時(shí)為登錄超時(shí) if(data.data.code === 10){ this.$Message.error("登錄已超時(shí),請(qǐng)重新登錄") this.$router.push("/login") //其余錯(cuò)誤狀態(tài)處理 }else if(data.data.code != 0){ this.$Message.error(data.data.msg) //請(qǐng)求成功 }else if(data.data.code === 0){ //進(jìn)行成功業(yè)務(wù)邏輯 } //....... });
如果不使用請(qǐng)求攔截,那么對(duì)每一條請(qǐng)求每一個(gè)狀態(tài)都要特殊處理,如果請(qǐng)求特殊狀態(tài)有數(shù)十個(gè),每個(gè)頁面有很多請(qǐng)求,那么頁面會(huì)變得很長(zhǎng)很臃腫,不好維護(hù)。
使用請(qǐng)求攔截
相同的請(qǐng)求返回代碼我們可以抽取出來,寫在請(qǐng)求攔截中
當(dāng)我們?cè)O(shè)置了攔截之后,在我們的組件代碼中可以簡(jiǎn)化很多,還是以登錄界面為例:
在main.js中
//請(qǐng)求發(fā)送攔截,把數(shù)據(jù)發(fā)送給后臺(tái)之前做些什么...... axios.interceptors.request.use((request) => { //這個(gè)例子中data是loginName和password let REQUEST_DATA = request.data //統(tǒng)一進(jìn)行qs模塊轉(zhuǎn)換 request.data = qs.stringify(REQUEST_DATA) //再發(fā)送給后臺(tái) return request; }, function (error) { // Do something with request error return Promise.reject(error); }); //請(qǐng)求返回?cái)r截,把數(shù)據(jù)返回到頁面之前做些什么... axios.interceptors.response.use((response) => { //特殊錯(cuò)誤處理,狀態(tài)為10時(shí)為登錄超時(shí) if (response.data.code === 10) { iView.Message.error("登錄已超時(shí),請(qǐng)重新登錄"); router.push("/login") //其余錯(cuò)誤狀態(tài)處理 } else if (response.data.code != 0) { iView.Message.error(response.data.msg) //請(qǐng)求成功 } else if(response.data.code === 0){ //將我們請(qǐng)求到的信息返回頁面中請(qǐng)求的邏輯 return response; } //...... }, function (error) { return Promise.reject(error); }); //雙向數(shù)據(jù)綁定獲取值 let httpRequest = {}; httpRequest.loginName = this.loginName httpRequest.password= this.password this.$axios.post("/api/request", httpRequest).then(data => { //這是要先判斷data,如果請(qǐng)求的數(shù)據(jù)狀態(tài)code不為0,會(huì)被攔截,則data為undefined if(data){ //進(jìn)行請(qǐng)求返回成功邏輯 } });
這樣我們就對(duì)axios請(qǐng)求添加了攔截,可以減少很多代碼邏輯,頁面可讀性更高,可維護(hù)性也更高
其他
這就是axios攔截的最基礎(chǔ)的用法,當(dāng)然也不止于此,我們也可以進(jìn)行擴(kuò)展延伸,做更多的事情,只要你的業(yè)務(wù)有需求,axios攔截總能幫到你,這些就需要舉一反三,工具是死的人是活的,我可以再舉個(gè)小例子,比如設(shè)置請(qǐng)求簽名。
請(qǐng)求簽名是前臺(tái)和后臺(tái)約定的一種溝通方式,對(duì)數(shù)據(jù)進(jìn)行加密,可以一定程度上保證數(shù)據(jù)的安全性
還是以這個(gè)登錄頁面為例
//雙向數(shù)據(jù)綁定獲取值 let httpRequest = {}; httpRequest.loginName = this.loginName httpRequest.password= this.password this.$axios.post("/api/request", httpRequest).then(data => { //這是要先判斷data,如果請(qǐng)求的數(shù)據(jù)狀態(tài)code不為0,會(huì)被攔截,則data為undefined if(data){ //進(jìn)行請(qǐng)求返回成功邏輯 } });
我們把httpRequest這個(gè)data信息數(shù)據(jù)發(fā)送給后臺(tái)之前,進(jìn)行簽名,并加密數(shù)據(jù)
在main.js中,我們對(duì)發(fā)送的數(shù)據(jù)進(jìn)行攔截
//請(qǐng)求發(fā)送攔截 axios.interceptors.request.use((request) => { //獲取請(qǐng)求的數(shù)據(jù),這里是loginName和password let REQUEST_DATA = request.data //獲取請(qǐng)求的地址,這里是/api/request let REQUEST_URL = request.url //設(shè)置簽名并進(jìn)行qs轉(zhuǎn)換,且賦值給request的data,簽名函數(shù)另外封裝 request.data = qs.stringify(requestDataFn(REQUEST_DATA, REQUEST_URL)) //發(fā)送請(qǐng)求給后臺(tái) return request; }, function (error) { // Do something with request error return Promise.reject(error); }); //已封裝好的簽名函數(shù) function requestDataFn(data, method) { let postData = {} //時(shí)間戳,時(shí)間戳函數(shù)不作展示,也是已封裝好的 postData.timestamp = getNowFormatDate(); //請(qǐng)求用戶的session以及secretKey信息,為空是未登錄,登錄后我把它存在localStorage中,這個(gè)存在哪里都可以,這里只作為例子。 postData.session = localStorage.getItem('session') || ''; postData.secretKey = localStorage.getItem('secretKey') || ''; //請(qǐng)求的地址,這里是/api/request postData.method = method; //請(qǐng)求的數(shù)據(jù)這里是loginName和password,進(jìn)行base64加密 let base64Data = Base64.encode(JSON.stringify(data)); //設(shè)置簽名并進(jìn)行md5加密 let signature = md5.hex(postData.secretKey + base64Data + postData.method + postData.session + postData.timestamp + postData.secretKey); //把數(shù)據(jù)再次進(jìn)行加密 postData.data = encodeURI(base64Data); postData.signature = signature; return postData }
上述就是小編為大家分享的怎么在Vue中利用axios攔截請(qǐng)求了,如果剛好有類似的疑惑,不妨參照上述分析進(jìn)行理解。如果想知道更多相關(guān)知識(shí),歡迎關(guān)注創(chuàng)新互聯(lián)成都網(wǎng)站設(shè)計(jì)公司行業(yè)資訊頻道。
另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內(nèi)外云服務(wù)器15元起步,三天無理由+7*72小時(shí)售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國(guó)服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡(jiǎn)單易用、服務(wù)可用性高、性價(jià)比高”等特點(diǎn)與優(yōu)勢(shì),專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場(chǎng)景需求。