Vue配置代理(devServer)解決跨域問題
1、作用:
Vue官方文檔的解釋是:
如果你的前端應用和后端 API 服務器沒有運行在同一個主機上,你需要在開發(fā)環(huán)境下將 API 請求代理到 API 服務器。這個問題可以通過
vue.config.js中的devServer.proxy選項來配置。
通俗的說,就是為了解決跨域問題。
2、用法:
本篇都以axios發(fā)請求為例,樣例如下:
axios.get("/abc/def");
axios.get("/abc/ghi");
axios.post("/abc/jkm");axios發(fā)送的請求是本地的服務器地址拼接上發(fā)送的請求,如 http://xxx:8080/abc/def
2.1 指定請求開頭配置
如果發(fā)送的請求都以 /abc 開頭,代理配置:
devServer: {
proxy: {
"/abc": {
target: "http://XX.XX.XX.XX:8081",
changeOrigin: true,
ws: true,
secure: false,
},
}
},- “/abc”:{} : 引號中代表,本代理配置,會檢測以 /abc 開頭的訪問
- target : 代表檢測到以 /abc 開頭的接口后,將請求中端口、地址,修改為后端接口地址,從而避免發(fā)生跨域問題
- changeOrigin : 是否修改數(shù)據(jù)包中host參數(shù),默認為true
- ws : 是否代理 websockets
- 該代理請求為:
http://localhost:8080/abc/def —> http://XX.XX.XX.XX:8081/abc/def
2.2 代理多個接口
請求示例:
// http://localhost:8080/zzz/one
axios.get("/zzz/one");
// http://localhost:8080/xxx/two
axios.get("/xxx/two");代理多接口方式1
監(jiān)測多個接口,可以在proxy中寫多個配置
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,
},
},
},代理多接口方式2
配置axios
// 只要發(fā)送axios請求,就在請求前加入/api的開頭,例如 /zzz/one -> /api/zzz/one axios.defaults.baseURL = "/api"; /* 進行了上方的配置后,在本地發(fā)送的請求會變?yōu)? http://localhost:8080/api/zzz/one http://localhost:8080/api/xxx/two */
配置代理
devServer: {
proxy: {
"/api": {
target: "http://XX.XX.XX.XX:8084",
changeOrigin: true,
ws: true,
pathRewrite: {
"^/api": "",
},
},
},
},
//pathRewrite :檢查代理的請求中是否有 /api ,有的話把 /api 替換為冒號后面的內容,案例為替換成空字符串,也就是刪去 /api 。(^是正則表達式的內容,意思是限定開頭)3、常見參數(shù)
target:"xxx", // 要使用url模塊解析的url字符串
forward:"xxx", // 要使用url模塊解析的url字符串
agent:{}, // 要傳遞給http(s).request的對象
ssl:{}, // 要傳遞給https.createServer()的對象
ws:true/false, // 是否代理websockets
xfwd:true/false, // 添加x-forward標頭
secure:true/false, // 是否驗證SSL Certs
toProxy:true/false, // 傳遞絕對URL作為路徑(對代理代理很有用)
prependPath:true/false, // 默認值:true 指定是否要將目標的路徑添加到代理路徑
ignorePath:true/false, // 默認值:false 指定是否要忽略傳入請求的代理路徑
localAddress:"xxx", // 要為傳出連接綁定的本地接口字符串
changeOrigin:true/false, // 默認值:false 將主機標頭的原點更改為目標URL到此這篇關于Vue配置代理(devServer),解決跨域問題的文章就介紹到這了,更多相關Vue配置代理(內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
解決vue+ element ui 表單驗證有值但驗證失敗問題
這篇文章主要介紹了vue+ element ui 表單驗證有值但驗證失敗,本文通過實例代碼給大家分享解決方案,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下2020-01-01
vue+vuex+axios+echarts畫一個動態(tài)更新的中國地圖的方法
本篇文章主要介紹了vue+vuex+axios+echarts畫一個動態(tài)更新的中國地圖的方法,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-12-12
vue2項目導出操作實現(xiàn)方法(后端接口導出、前端直接做導出)
這篇文章主要給大家介紹了關于vue2項目導出操作實現(xiàn)方法的相關資料,文中介紹的是后端接口導出、前端直接做導出,通過代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考借鑒價值,需要的朋友可以參考下2024-05-05

