Vue腳手架配置代理服務(wù)器的兩種方式(小結(jié))
1 前言
本文主要介紹使用Vue腳手架配置代理服務(wù)器的兩種方式
注意:Vue腳手架給我們提供了兩種配置代理服務(wù)器的方式,各有千秋,使用的時(shí)候只能二選一,不能同時(shí)使用
2 代理
除了cros和jsonp,還有一種代理方式,這種用的相對來說也很多, 一般代理服務(wù)器
這個(gè)概念很好理解,相當(dāng)于生活中的中介
在前后端直接配置一個(gè)代理服務(wù)器,這個(gè)代理服務(wù)器和前端處于一個(gè)位置,當(dāng)前端向后端請求數(shù)據(jù)的時(shí)候,不會(huì)直接訪問后端,而是找這臺(tái)代理,代理收到前端的請求,轉(zhuǎn)發(fā)給后端,如果收到后端的響應(yīng)數(shù)據(jù),就把這些數(shù)據(jù)返回給前端
代理服務(wù)器的方式有一個(gè)東西大家應(yīng)該都聽說過:nginx,但是nginx一般屬于后端人員掌握的,這里使用一種對前端人員更加友好的技術(shù):cli,沒錯(cuò),就是vue的腳手架,它就可以幫助我們代理服務(wù)器,相比nginx它簡單的不能再簡單了,只需要短短幾行代碼就可以搞定
vue腳手架配置方式1
既然想對腳手架進(jìn)行配置,肯定要改一個(gè)文件,就是vue的配置文件:vue.config.js,肯定要在這里面寫代碼,然后代理服務(wù)器就開起來了,到底怎么寫,可以參考官方文檔:Vue腳手架代理

復(fù)制配置代碼進(jìn)行修改配置文件
注意:這里的端口是要請求后端的端口,并且只需要寫到端口即可,我的后端端口是9090
// 開啟代理服務(wù)器
devServer: {
// 代理的端口是要請求后端的端口 寫到具體的端口即可 不需要寫具體的路徑
proxy: 'http://localhost:9090'
}
注意:這種代理簡單,但是不完美,原因在下面

這樣就配置了一個(gè)代理服務(wù)器,一定要重啟腳手架
重啟完成后再次訪問,還是報(bào)錯(cuò)跨域問題!

注意:雖然已經(jīng)配置了代理服務(wù)器,但是還沒用到這個(gè)代理,所以請求的時(shí)候不應(yīng)該是后端的端口9090,而是代理的端口8080,這里就要寫全路徑了,不能和配置代理服務(wù)器的時(shí)候一樣只寫端口了

再次訪問,發(fā)現(xiàn)正常了,說明代理有效

這種代理有兩個(gè)誤區(qū)(坑),下面一一說明
兩個(gè)誤區(qū)(坑)
誤區(qū)1
不能靈活的控制到底走不走代理
首先,這種代理不是什么都會(huì)代理給后端的,如果代理的東西前端有,就會(huì)直接返回,就不去找后端,比如下面這個(gè)例子
我在public目錄寫一個(gè)叫queryUserInfo的文件,沒錯(cuò),和后端的接口名稱一樣


這時(shí)候請求就會(huì)發(fā)現(xiàn),找到前端的內(nèi)容就不會(huì)訪問后端了

誤區(qū)2
這種代理只能代理一個(gè)服務(wù)器不能代理多個(gè)服務(wù)器,也就是說目前代理的8080只能把請求交給9090,不能轉(zhuǎn)發(fā)給別人了
vue腳手架配置方式2
上面的代理方式,雖然簡單,但是也有兩個(gè)坑,不夠完美,想要追求完美,還得是這種方式
那么這種方式怎么寫呢?還是繼續(xù)看官方文檔:Vue腳手架代理
注意:這種配置代理和上面的配置代理只能二選一,不能同時(shí)使用!

把代碼復(fù)制到配置文件,進(jìn)行修改
devServer: {<!--{cke_protected}{C}%3C!%2D%2D%20%2D%2D%3E-->proxy: {<!--{cke_protected}{C}%3C!%2D%2D%20%2D%2D%3E-->'/api': {<!--{cke_protected}{C}%3C!%2D%2D%20%2D%2D%3E-->target: '<url>',ws: true,changeOrigin: true},'/foo': {<!--{cke_protected}{C}%3C!%2D%2D%20%2D%2D%3E-->target: '<other_url>'}}}這里面有一些屬性,有的屬性可以配置使用,我們一一說明
注意:不管修改哪個(gè)屬性,都要重啟vue!
/api和target
/api指的是請求前綴 這里的api可以更改 不一定非要叫api
target指的是如果請求前綴匹配上了,那么就找代理服務(wù)器請求
比如現(xiàn)在我請求的路徑不變還是上面的路徑

那么還是一樣的效果

這時(shí)候我把a(bǔ)pi前綴加上,理論來說可以了,但是還是不行

不過這次不是跨域的問題了,只是找不到請求

找不到請求是對的,因?yàn)榈暮蠖苏埱鬀]有/api的前綴,那么如果忽略這個(gè)前綴呢?
pathRewrite
有這么一個(gè)屬性,官方?jīng)]有說:pathRewrite
// 忽略前綴路徑 它是一個(gè)對象 里面是key value
// 這個(gè)正則意思是 如果前綴是/api,那么會(huì)替換成空字符
pathRewrite:{'^/api':''}

這個(gè)時(shí)候再測試,發(fā)現(xiàn)正常

ws
ws是websocket的縮寫,用于支持websocket,默認(rèn)為true,本人對websocket不是很了解,所以不多敘述!
changeOrigin
用于控制請求頭中的host值
或者說是否真實(shí)匯報(bào)自身情況 true不真實(shí) false真實(shí) 一般為true,默認(rèn)也是true
為什么這么說呢?我們通過下面案例查看,這時(shí)候我后端獲取請求的主機(jī)信息,大家注意觀察


改為false,好家伙,你小子反水是吧


配置多個(gè)代理
如果想要配置多個(gè)代理,直接復(fù)制一個(gè)即可,注意加上逗號,修改端口和前綴

3 vue腳手架配置代理總結(jié)
vue腳手架配置代理
方法一
在vue.config.js中添加如下配置:
devServer:{
proxy:"http://localhost:5000"
}
說明:
1. 優(yōu)點(diǎn):配置簡單,請求資源時(shí)直接發(fā)給前端(8080)即可。
2. 缺點(diǎn):不能配置多個(gè)代理,不能靈活的控制請求是否走代理。
3. 工作方式:若按照上述配置代理,當(dāng)請求了前端不存在的資源時(shí),那么該請求會(huì)轉(zhuǎn)發(fā)給服務(wù)器 (優(yōu)先匹配前端資源)
方法二
編寫vue.config.js配置具體代理規(guī)則:
module.exports = {
devServer: {
proxy: {
'/api1': {// 匹配所有以 '/api1'開頭的請求路徑
target: 'http://localhost:5000',// 代理目標(biāo)的基礎(chǔ)路徑
changeOrigin: true,
pathRewrite: {'^/api1': ''}
},
'/api2': {// 匹配所有以 '/api2'開頭的請求路徑
target: 'http://localhost:5001',// 代理目標(biāo)的基礎(chǔ)路徑
changeOrigin: true,
pathRewrite: {'^/api2': ''}
}
}
}
}
/*
changeOrigin設(shè)置為true時(shí),服務(wù)器收到的請求頭中的host為:localhost:5000
changeOrigin設(shè)置為false時(shí),服務(wù)器收到的請求頭中的host為:localhost:8080
changeOrigin默認(rèn)值為true
*/
說明:
1. 優(yōu)點(diǎn):可以配置多個(gè)代理,且可以靈活的控制請求是否走代理。
2. 缺點(diǎn):配置略微繁瑣,請求資源時(shí)必須加前綴。
到此這篇關(guān)于Vue腳手架配置代理服務(wù)器的兩種方式(小結(jié))的文章就介紹到這了,更多相關(guān)Vue腳手架配置代理服務(wù)器內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
vue + elementUI實(shí)現(xiàn)省市縣三級聯(lián)動(dòng)的方法示例
這篇文章主要介紹了vue + elementUI實(shí)現(xiàn)省市縣三級聯(lián)動(dòng)的方法示例,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-10-10
Vue實(shí)現(xiàn)網(wǎng)頁轉(zhuǎn)PDF方法流程詳解
在日常的工作中,有時(shí)候會(huì)碰到需要將某個(gè)網(wǎng)址網(wǎng)頁保存成為pdf的情況,這篇文章主要介紹了用Vue實(shí)現(xiàn)網(wǎng)頁轉(zhuǎn)PDF的方法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2022-08-08
解決vue net :ERR_CONNECTION_REFUSED報(bào)錯(cuò)問題
這篇文章主要介紹了解決vue net :ERR_CONNECTION_REFUSED報(bào)錯(cuò)問題,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-08-08
vue內(nèi)置組件transition簡單原理圖文詳解(小結(jié))
這篇文章主要介紹了vue內(nèi)置組件transition簡單原理圖文詳解(小結(jié)),小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2018-07-07
Vue項(xiàng)目通過vue-i18n實(shí)現(xiàn)國際化方案(推薦)
這篇文章主要介紹了Vue項(xiàng)目通過vue-i18n實(shí)現(xiàn)國際化方案,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-12-12
Vue3實(shí)現(xiàn)LuckSheet在線預(yù)覽Excel表格
在前端開發(fā)中預(yù)覽Excel文件是常見的需求之一,本文將介紹如何使用Vue.js框架以及兩個(gè)優(yōu)秀的Excel庫——LuckyExcel和Luckysheet,來實(shí)現(xiàn)Excel文件在線預(yù)覽功能,希望對大家有所幫助2023-11-11
element使用自定義icon圖標(biāo)的詳細(xì)步驟
前端經(jīng)常會(huì)用到UI提供的各種圖表,推薦阿里的圖標(biāo)庫,下面這篇文章主要給大家介紹了關(guān)于element使用自定義icon圖標(biāo)的詳細(xì)步驟,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2022-11-11
vue實(shí)現(xiàn)路由懶加載及組件懶加載的方式
懶加載簡單來說就是延遲加載或按需加載,即在需要的時(shí)候的時(shí)候進(jìn)行加載。這篇文章主要介紹了vue路由懶加載及組件懶加載 ,需要的朋友可以參考下2019-06-06
vue如何實(shí)現(xiàn)角色權(quán)限的控制
關(guān)于角色與權(quán)限控制,通常是分為兩大類,一種是菜單權(quán)限,一種是操作權(quán)限,本文將深入探討如何通過?Vue?實(shí)現(xiàn)角色權(quán)限控制,特別是基于按鈕級別的權(quán)限控制,需要的可以了解下2025-02-02
淺析webpack-bundle-analyzer在vue-cli3中的使用
這篇文章主要介紹了webpack-bundle-analyzer在vue-cli3中的使用,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2019-10-10

