Vue配置文件中的devServer proxy配置全過(guò)程
1.如果發(fā)送的請(qǐng)求都以 /abc 開(kāi)頭
那么我們就可以在proxy中進(jìn)行服務(wù)器代理配置。
這里以axios發(fā)請(qǐng)求為例
axios.get("/abc/def");
axios.get("/abc/ghi");
axios.post("/abc/jkm");devServer: {
host: 'localhost',
port: 8080,//自定義
open: true,
proxy: {
"/abc": {
target: "http://XX.XX.XX.XX:8081",
changeOrigin: true,
ws: true,
secure: false,
},
},
},"/abc":{}: 引號(hào)中代表監(jiān)測(cè)的是以 /abc 開(kāi)頭的接口target: 代表監(jiān)測(cè)到以 /abc 開(kāi)頭的接口后,把a(bǔ)xios請(qǐng)求中前面的本地服務(wù)器地址改為后端接口地址,實(shí)際發(fā)送給后端的請(qǐng)求就是下方后一個(gè)請(qǐng)求 http://localhost:8080/abc/def --> http://XX.XX.XX.XX:8081/abc/defchangeOrigin: 是否跨域ws: 如果要代理 websockets,配置這個(gè)參數(shù)secure: 如果是https接口,需要配置這個(gè)參數(shù)(如果是http接口,也可以不寫(xiě)這個(gè)參數(shù))pathRewrite:替換請(qǐng)求中匹配的內(nèi)容。上方未使用此參數(shù)
2.代理多個(gè)接口
( 即發(fā)送的請(qǐng)求不是都以 /abc 開(kāi)頭,例如下圖)
axios.get("/zzz/one");
axios.get("/xxx/two");- http://localhost:8080/zzz/one
- http://localhost:8080/xxx/two
方法1:監(jiān)測(cè)多個(gè)接口,可以在proxy中寫(xiě)多個(gè)配置:(適用于target不同的代理)
devServer: {
proxy: {
"/zzz": {
target: "http://XX.XX.XX.XX:8082",
changeOrigin: true,
ws: true,
},
"/xxx": {
target: "http://XX.XX.XX.XX:8083",
changeOrigin: true,
ws: true,
},
},
},那么實(shí)際發(fā)送給后端的請(qǐng)求就是:
- http://XX.XX.XX.XX:8082/zzz/one
- http://XX.XX.XX.XX:8083/xxx/two
方法2:使用axios進(jìn)行前設(shè)置(適用于target相同的代理)
// 一般在全局設(shè)置里引入,例如main.js,方便第二行的配置被每一個(gè)axios請(qǐng)求識(shí)別 import axios from "axios"; // 只要發(fā)送axios請(qǐng)求,就在請(qǐng)求前加入/api的開(kāi)頭,例如 /zzz/one -> /api/zzz/one axios.defaults.baseURL = "/api";
進(jìn)行了上方的配置后,在本地發(fā)送的請(qǐng)求會(huì)變?yōu)?/p>
- http://localhost:8080/api/zzz/one
- http://localhost:8080/api/xxx/two
而后可以設(shè)置只監(jiān)聽(tīng) "/api" 的代理,不過(guò)要設(shè)置pathRewrite參數(shù):
devServer: {
proxy: {
"/api": {
target: "http://XX.XX.XX.XX:8084",
changeOrigin: true,
ws: true,
pathRewrite: {
"^/api": "",
},
},
},
},pathRewrite :檢查代理的請(qǐng)求中是否有 /api ,有的話把 /api 替換為冒號(hào)后面的內(nèi)容,案例為替換成空字符串,也就是刪去 /api 。(^是正則表達(dá)式的內(nèi)容,意思是限定開(kāi)頭)
- 本地請(qǐng)求 http://localhost:8080/api/zzz/one ->
- 代理后請(qǐng)求 http://XX.XX.XX.XX:8084/api/zzz/one ->
- 設(shè)置pathRewrite后的請(qǐng)求 http://XX.XX.XX.XX:8084/zzz/one
- 所以代理完成后真正發(fā)送給后端的請(qǐng)求就是 http://XX.XX.XX.XX:8084/zzz/one
總結(jié)
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
vue 監(jiān)聽(tīng)屏幕高度的實(shí)例
今天小編就為大家分享一篇vue 監(jiān)聽(tīng)屏幕高度的實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-09-09
解決Vue.js由于延時(shí)顯示了{(lán){message}}引用界面的問(wèn)題
今天小編就為大家分享一篇解決Vue.js由于延時(shí)顯示了{(lán){message}}引用界面的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-08-08
vue實(shí)現(xiàn)簡(jiǎn)單的分頁(yè)功能
這篇文章主要為大家詳細(xì)介紹了vue實(shí)現(xiàn)簡(jiǎn)單的分頁(yè)功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-03-03
關(guān)于element?ui?表格中的常見(jiàn)特殊屬性說(shuō)明
這篇文章主要介紹了關(guān)于element?ui?表格中的常見(jiàn)特殊屬性說(shuō)明,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-08-08
前端插件庫(kù)之vue3使用vue-codemirror插件的步驟和實(shí)例
CodeMirror是一款基于JavaScript、面向語(yǔ)言的前端代碼編輯器,下面這篇文章主要給大家介紹了關(guān)于前端插件庫(kù)之vue3使用vue-codemirror插件的步驟和實(shí)例,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2022-07-07

