vue-cil之a(chǎn)xios的二次封裝與proxy反向代理使用說明
Axios與proxy反向代理
Axios 是一個基于 promise 的 HTTP 庫,可以用在瀏覽器和 node.js 中。
1、Axios 的特性
- 從瀏覽器中創(chuàng)建 XMLHttpRequests
- 從 node.js 創(chuàng)建 http 請求
- 支持 Promise API
- 攔截請求和響應(yīng)
- 轉(zhuǎn)換請求數(shù)據(jù)和響應(yīng)數(shù)據(jù)
- 取消請求
- 自動轉(zhuǎn)換 JSON 數(shù)據(jù)
- 客戶端支持防御 XSRF
2、Axios 的安裝
npm i axios # 或者 yran add axios
3、Axios 與proxy反向代理的使用
在要進行使用的文件(request.js)里面導(dǎo)入
// 這是實現(xiàn) axios 的二次分裝 // 導(dǎo)入下載好的包 impront axios from 'axios' // 創(chuàng)建 axios 實例 const service = axios.create({ ? ? // 添加要對接的后端 url 接口 ? ? // bassUrl: '<url>', ? ? // 設(shè)置超時時間 ? ? timeout: 3000 }) // 請求攔截 service.interceptors.request.use(config => { ? ? // 可以添加一些響應(yīng)頭信息等 ? ?? ? ? return config })? // 響應(yīng)攔截 service.interceptors.response.use(res => { ? ? console.log('請求攔截', res) ? ? return res }) // 導(dǎo)出 export default service
如果是對接多個后端接口,前端應(yīng)用和后端API服務(wù)器沒有運行在同一個主機上,你需要在開發(fā)環(huán)境下將API請求代理到 API服務(wù)器,就在vue.config.js 中書寫如下代碼
// vue.config.js module.exports = { ? devServer:{ ? ? ? // 更改端口號 ? ? ? port: 9550, ? ? ? // 是否自動打開瀏覽器 ? ? ? open: true, ? ? ? proxy: { ? ? ? ?// 這里是訪問到以 /api 開頭的 url 的時候會代理到target 目標(biāo)上 ? ? ? ?? ?'/api': { ? ? ? ?? ??? ?target:'<url>', ? ? ? ?? ??? ?ws: true, ? ? ? ?? ??? ?changeOrigin:true, ? ? ? ?? ??? ?// 重新修改路徑 ? ? ? ?? ??? ?pathRewrite: { ? ? ? ?? ??? ??? ?'^/api': '' ? ?? ??? ??? ?} ? ?? ??? ?} ? ?? ?} ? } }
注:為什么要重新修改路徑,因為在發(fā)送請求后會在url中多拼接上一個 ’‘ /api ’‘ ,但是我們獲取數(shù)據(jù)又不需要這個才能拿到,所以就要重新修改,把他拿掉;拿掉之后就可以獲取到數(shù)據(jù)了
最后那個地方需要就直接導(dǎo)入service 然后調(diào)用就行了
axios反向代理proxy個人理解
使用反向代理proxy的原因
首先需要了解瀏覽器的同源策略,同源就是說比如你VUE的項目地址是“http://localhost:8080”,而你后端項目啟動地址是‘http://localhost:9999’,兩者中協(xié)議(http)、域名(localhost)相同,但是端口號(:xxxx)vue是8080,而后端是9999不相同,所以產(chǎn)生跨域,需要使用反向代理。(若兩者滿足協(xié)議、域名、端口號相同則不存在跨域問題)。
反向代理在我個人理解就是給你vue項目訪問后端資源時給你套上的一個殼,讓瀏覽器認(rèn)為本次請求是同源的,瀏覽器就不會進行攔截,數(shù)據(jù)可以正常返回(類似vpn原理吧)。
proxy基本配置
module.exports = { ?? ?devServer: { ?? ??? ?proxy: { ?? ??? ??? ?'/proxyurl':{ ?? ??? ??? ??? ?target:'http://localhost:9999',//起同源作用的url 簡單來說就是你要訪問的服務(wù)器 ?? ??? ??? ??? ?//ws: true, 這個是 開啟websocket ?? ??? ??? ??? ?changeOrigin: true,//字面意思:更改源點 很多人說是開啟跨域 也可以這么理解 ?? ??? ??? ??? ?pathRewrite: { ?? ??? ??? ??? ??? ?'^/proxyurl': '' //還有一種寫法是'^/proxyurl': '/' 自測 ?? ??? ??? ??? ?} ?? ??? ??? ?} ?? ??? ?} ?? ?} }
//寫個最簡單的例子用法 //前端項目地址是 http://localhost:8080 //后端項目地址是 http://localhost:9999 ?? ?axios.get("/proxyurl/user/getalluser").then(res => { ?? ??? ?console.log(res); ?? ?});
解釋這個例子:
顯然我們是通過vue項目訪問了后端資源,拋開代理單看這段代碼,是以http://localhost:8080/proxyurl/user/getalluser請求資源的。
但是有了反向代理,反向代理看到了你這段url中出現(xiàn)了’/proxyurl‘,反向代理起作用,將’/proxyurl‘前面這段’http://localhost:8080‘替換成了’http://localhost:9999‘,這時候請求資源的url變?yōu)?lsquo;http://localhost:9999/proxyurl/user/getalluser’。
但是我們又配置了一項pathRewrite: {'^/proxyurl': ''},'^/proxyurl'是正則表達式,它會匹配你url中的字符串。這一選項的代碼意思是,將url中的’/proxyurl‘替換為空字符串。則現(xiàn)在的url是http://localhost:9999/user/getalluser
ps:通常我們會將axios封裝,可以在創(chuàng)建axios實例時這樣寫
export function request(config){ ? ? let axiosInstance = axios.create({ ? ? ? ? baseURL: '/proxyurl', //在調(diào)用時拼接上后面的url就可以了 ? ? ? ? timeout: 5000 ? ? }); ? ? return axiosInstance(config); }
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
vue實現(xiàn)拖拽的簡單案例 不超出可視區(qū)域
這篇文章主要為大家詳細(xì)介紹了vue實現(xiàn)拖拽的簡單案例,不超出可視區(qū)域,具有一定的參考價值,感興趣的小伙伴們可以參考一下2019-07-07Vue讀取本地靜態(tài).md并側(cè)邊欄導(dǎo)航跳轉(zhuǎn)、展示.md文件的操作方法
這篇文章主要介紹了Vue讀取本地靜態(tài).md并側(cè)邊欄導(dǎo)航跳轉(zhuǎn)、展示.md文件,本文通過實例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2023-08-08Vue實現(xiàn)hash模式網(wǎng)址方式(就是那種帶#的網(wǎng)址、井號url)
這篇文章主要介紹了Vue實現(xiàn)hash模式網(wǎng)址方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-07-07