Vue 調(diào)試訪問本地后端接口配置
Vue 調(diào)試訪問本地后端接口配置
記錄一下本地測試前端的時(shí)候怎么訪問本地后端接口。時(shí)間太長容易忘。。。。
1、首先要知道前端在訪問后端的時(shí)候是怎么加上后端接口地址的。
如下圖,找到封裝http請求的文件,src/utils/rerquest.js
該圖中的baseURL就是訪問時(shí)我們加上的后端請求地址。baseURL: process.env.VUE_APP_BASE_API 表示baseURL使用的是環(huán)境變量中的VUE_APP_BASE_API這個(gè)參數(shù)
在本地測試前端的時(shí)候使用的命令一般都是npm run dev
然后dev使用的默認(rèn)環(huán)境變量文件是 .env.development
簡單來說,只要在.env.development中配置了VUE_APP_BASE_API參數(shù),那么在本地測試的時(shí)候默認(rèn)使用的后端地址就是在這個(gè)文件中配置的地址。
一篇看懂 vue 如何做調(diào)試后臺接口的配置和 proxy 的工作原理 以及為什么能解決跨域
之前也做過不少vue項(xiàng)目了,每次跟后臺配合的時(shí)候,有些配置總是會忘記,感覺每次的解決方案和上一次的都不一樣,所以這次準(zhǔn)備詳細(xì)的記錄一下,如何做配置,以及一些配置的含義
話不多說 直接開始
1.首先要想調(diào)取后臺接口一定要引入的就是axios,所以第一步就是下載 axios
npm install axios
2.在需要調(diào)用接口的頁面引入axios
import axios from 'axios'
2.1發(fā)送請求
axios({ method: "post", url: "接口地址", data: this.data, headers: { "Content-Type": "multipart/form-data" }, }).then(e => { console.log(e) })
此時(shí)不出意外控制臺應(yīng)該是報(bào)錯了,應(yīng)該是報(bào)的跨域的錯,此時(shí)就要做一下對vue.config.js 文件的配置
2.2 vue.config.js
為什么要配置這么文件呢,配置這個(gè)文件的目的是什么呢?
因?yàn)槲覀冎罏g覽器和服務(wù)器之間會存在跨域問題,但是兩個(gè)服務(wù)器之間確實(shí)可以隨意訪問的,所以我們要配置一個(gè)代理服務(wù)器來調(diào)用用服務(wù)器的接口,如果你的前端應(yīng)用和后端 API 服務(wù)器沒有運(yùn)行在同一個(gè)主機(jī)上,你需要在開發(fā)環(huán)境下將 API 請求代理到 API 服務(wù)器,此時(shí)可以通過 vue.config.js 中的 devServer.proxy 選項(xiàng)來配置。
devServer: { port: '9080', open: true, proxy: { '/api': { target: 'http://192.168.2.108:9080/crm',//代理地址,這里設(shè)置的地址會代替axios中設(shè)置的baseURL secure: false, //如果是https接口需要進(jìn)行此配置 changeOrigin: true,// 如果接口跨域,需要進(jìn)行這個(gè)參數(shù)配置 //pathRewrite方法重寫url pathRewrite: { '^/api': '/aaa' //如果沒有pathRewrite屬性 調(diào)用的接口就是http://cloud/api/xxx/xxxx 如果有 pathRewrite屬性 調(diào)用的接口就是 http://cloud/aaa/xxx/xxxx } } } }, },
devServer里面proxy則是關(guān)于代理的配置,該屬性為對象的形式,對象中每一個(gè)屬性就是一個(gè)代理的規(guī)則匹配
屬性的名稱是需要被代理的請求路徑前綴,一般為了辨別都會設(shè)置前綴為/api,值為對應(yīng)的代理匹配規(guī)則,對應(yīng)如下:
tip: 如果接口地址沒有一個(gè)統(tǒng)一的前綴 如 /api 可以設(shè)置一個(gè) axios.defaults.baseURL = ‘/api’ 即可為所有接口地址添加一個(gè)統(tǒng)一的前綴 /api
target:表示的是代理到的目標(biāo)地址
pathRewrite:默認(rèn)情況下,我們的 /api 也會被寫入到URL中,如果希望刪除,可以使用pathRewrite 如果你的接口中本身就帶有 /api 可以不寫 pathRewrite
secure:默認(rèn)情況下不接收轉(zhuǎn)發(fā)到https的服務(wù)器上,如果希望支持,可以設(shè)置為false
changeOrigin:它表示是否更新代理后請求的 headers 中host地址
3.工作原理
proxy實(shí)質(zhì)就是一個(gè)代理服務(wù)器 這樣就能理解 proxy 工作原理實(shí)質(zhì)上是利用http-proxy-middleware 這個(gè)http代理中間件,實(shí)現(xiàn)請求轉(zhuǎn)發(fā)給其他服務(wù)器
舉個(gè)例子:
在開發(fā)階段,本地地址為http://localhost:3000,該瀏覽器發(fā)送一個(gè)前綴帶有/api標(biāo)識的請求到服務(wù)端獲取數(shù)據(jù),但響應(yīng)這個(gè)請求的服務(wù)器只是將請求轉(zhuǎn)發(fā)到另一臺服務(wù)器中
說的再通俗一點(diǎn) 就是 A(瀏覽器) 想認(rèn)識(發(fā)請求) C(服務(wù)器) 但是 由于礙于面子(同源政策) 只能 通過 B(proxy) 來介紹,也就是 A 發(fā)送請求給 B 再由 B 轉(zhuǎn)發(fā)請求給 C
4.跨域
在開發(fā)階段,devServer 會啟動一個(gè)本地開發(fā)服務(wù)器,所以我們的應(yīng)用在開發(fā)階段是獨(dú)立運(yùn)行在 localhost的一個(gè)端口上,而后端服務(wù)又是運(yùn)行在另外一個(gè)地址上
所以在開發(fā)階段中,由于瀏覽器同源策略的原因,當(dāng)本地訪問后端就會出現(xiàn)跨域請求的問題
通過設(shè)置 proxy 實(shí)現(xiàn)代理請求后,相當(dāng)于瀏覽器與服務(wù)端中添加一個(gè)代理者
當(dāng)本地發(fā)送請求的時(shí)候,代理服務(wù)器響應(yīng)該請求,并將請求轉(zhuǎn)發(fā)到目標(biāo)服務(wù)器,目標(biāo)服務(wù)器響應(yīng)數(shù)據(jù)后再將數(shù)據(jù)返回給代理服務(wù)器,最終再由代理服務(wù)器將數(shù)據(jù)響應(yīng)給本地
在代理服務(wù)器傳遞數(shù)據(jù)給本地瀏覽器的過程中,兩者同源,并不存在跨域行為,這時(shí)候?yàn)g覽器就能正常接收數(shù)據(jù)
到此這篇關(guān)于Vue 調(diào)試訪問本地后端接口配置的文章就介紹到這了,更多相關(guān)vue后端接口配置內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
uniapp中如何基于vue3實(shí)現(xiàn)輸入驗(yàn)證碼功能
本文介紹了如何使用uniapp和vue3創(chuàng)建一個(gè)手機(jī)驗(yàn)證碼輸入框組件,通過封裝VerificationCodeInput.vue組件,并在父組件中引入,可以實(shí)現(xiàn)驗(yàn)證碼輸入功能,適合需要增加手機(jī)驗(yàn)證碼驗(yàn)證功能的開發(fā)者參考使用2024-09-09vue前端開發(fā)輔助函數(shù)狀態(tài)管理詳解示例
vue的應(yīng)用狀態(tài)管理提供了mapState、mapGetters、mapMutations、mapActions四個(gè)輔助函數(shù),所謂的輔助函數(shù)分別對State、Getters、Mutations、Actions在完成狀態(tài)的使用進(jìn)行簡化2021-10-10web開發(fā)中如何優(yōu)雅的解決"重復(fù)請求"問題
在我們的日常開發(fā)當(dāng)中,很多時(shí)候會出現(xiàn)短時(shí)間內(nèi)重復(fù)請求的情況,如果沒有妥當(dāng)?shù)靥幚砗蠊車?yán)重,這篇文章主要給大家介紹了關(guān)于web開發(fā)中如何優(yōu)雅的解決重復(fù)請求問題的相關(guān)資料,需要的朋友可以參考下2022-05-05Vue3實(shí)現(xiàn)一個(gè)定高的虛擬列表
虛擬列表對于大部分一線開發(fā)同學(xué)來說是一點(diǎn)都不陌生的東西了,這篇文章主要來教大家如何在2分鐘內(nèi)實(shí)現(xiàn)一個(gè)定高的虛擬列表,感興趣的可以了解下2024-12-12sublime如何配置開發(fā)VUE環(huán)境自動格式化代碼
這篇文章主要介紹了sublime如何配置開發(fā)VUE環(huán)境自動格式化代碼問題,具有很好的參考價(jià)值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-03-03Vue文件下載進(jìn)度條的實(shí)現(xiàn)過程
這篇文章主要介紹了Vue文件下載進(jìn)度條的實(shí)現(xiàn)原理,通過使用onDownloadProgress方法API獲取進(jìn)度及文件大小等數(shù)據(jù),本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-07-07Vue?element-ui中表格過長內(nèi)容隱藏顯示的實(shí)現(xiàn)方式
在Vue項(xiàng)目中,使用ElementUI渲染表格數(shù)據(jù)時(shí),如果某一個(gè)列數(shù)值長度超過列寬,會默認(rèn)換行,造成顯示不友好,下面這篇文章主要給大家介紹了關(guān)于Vue?element-ui中表格過長內(nèi)容隱藏顯示的實(shí)現(xiàn)方式,需要的朋友可以參考下2022-09-09