webpack+vue-cil 中proxyTable配置接口地址代理操作
在項(xiàng)目開發(fā)的時(shí)候,接口聯(lián)調(diào)的時(shí)候一般都是同域名下,且不存在跨域的情況下進(jìn)行接口聯(lián)調(diào),但是當(dāng)我們現(xiàn)在使用vue-cli進(jìn)行項(xiàng)目打包的時(shí)候,我們?cè)诒镜貑?dòng)服務(wù)器后,比如本地開發(fā)服務(wù)下是 http://localhost:8080 這樣的訪問(wèn)頁(yè)面,但是我們的接口地址是 http://xxxx.com/save/index 這樣的接口地址,我們這樣直接使用會(huì)存在跨域的請(qǐng)求,導(dǎo)致接口請(qǐng)求不成功,因此我們需要在打包的時(shí)候配置一下,我們進(jìn)入 config/index.js 代碼下如下配置即可:
dev: { // 靜態(tài)資源文件夾 assetsSubDirectory: 'static', // 發(fā)布路徑 assetsPublicPath: '/', // 代理配置表,在這里可以配置特定的請(qǐng)求代理到對(duì)應(yīng)的API接口 // 例如將'localhost:8080/api/xxx'代理到'www.example.com/api/xxx' // 使用方法:https://vuejs-templates.github.io/webpack/proxy.html proxyTable: { '/api': { target: 'http://xxxxxx.com', // 接口的域名 // secure: false, // 如果是https接口,需要配置這個(gè)參數(shù) changeOrigin: true, // 如果接口跨域,需要進(jìn)行這個(gè)參數(shù)配置 pathRewrite: { '^/api': '' } } }, // 本地訪問(wèn) http://localhost:8080 host: 'localhost', // can be overwritten by process.env.HOST
接口地址原本是 /save/index,但是為了匹配代理地址,在前面加一個(gè) /api, 因此接口地址需要寫成這樣的即可生效 /api/save/index。
注意: '/api' 為匹配項(xiàng),target 為被請(qǐng)求的地址,因?yàn)樵?ajax 的 url 中加了前綴 '/api',而原本的接口是沒有這個(gè)前綴的,所以需要通過(guò) pathRewrite 來(lái)重寫地址,將前綴 '/api' 轉(zhuǎn)為 '/'。如果本身的接口地址就有 '/api' 這種通用前綴,就可以把 pathRewrite 刪掉。
補(bǔ)充知識(shí):webpack -- 關(guān)于proxyTable的配置在開發(fā)環(huán)境和生產(chǎn)環(huán)境中的原理解析
前言
首先,proxyTable是我們?cè)诒镜亻_發(fā)環(huán)境中調(diào)試接口用的,目的是為了解決本地跨域的問(wèn)題,因?yàn)楸镜氐刂窞閘ocalhost:xxxx/xxx
在線上的生產(chǎn)環(huán)境是沒用的?。?!
假設(shè)我們用的是vue-cli命令行工具生成的webpack項(xiàng)目模板,我們很容易能在config文件夾下面找到index.js文件。
本地如何配置
假設(shè)我要請(qǐng)求的地址為
'http://xxx.com/scada/json/aa.tpl'
我們?cè)趇ndex.js文件中找到如下代碼:我推薦了一種寫法,后面我會(huì)說(shuō)為什么
那么我請(qǐng)求的那段代碼就是這樣的
axios.get('/scada/json/aa.tpl').then((res) => { //........ })
稍微解釋一下其中的原理:當(dāng)發(fā)請(qǐng)求的時(shí)候,proxy就會(huì)起作用,他會(huì)在接口'/scada'前面加上 ‘http://xxx.com:123',成為 ‘http://xxx.com:123/scada/json/aa.tpl' 由于我們配置中的 pathRewrite字段需要將 '/scada'寫為 ‘/scada',所以請(qǐng)求接口還是 ‘http://xxx.com:123/scada/json/aa.tpl'
繼續(xù)向下看,干貨還在后面
假設(shè)幾種其它的寫法
假設(shè)一
如果proxyTable配置是這樣的
proxyTable: { '/scada': { target: 'http://xxx.com:123', changeOrigin: true, pathRewrite: { '^/scada': '/' } }
那么我們的請(qǐng)求代碼必須寫成這樣
axios.get('/scada/scada/json/aa.tpl').then((res) => { //........ //是不是有點(diǎn)難受 })
假設(shè)二
如果proxyTable配置是這樣的,也就是重新起個(gè)名字
proxyTable: { '/api': { target: 'http://xxx.com:123', changeOrigin: true, pathRewrite: { '^/api': '/' } }
那么我們的請(qǐng)求代碼必須寫成這樣
axios.get('/api/scada/json/aa.tpl').then((res) => { //........ //這種寫法還能接受,但是有個(gè)致命的缺點(diǎn) })
再向下看,看看我推薦的寫法的真真優(yōu)勢(shì)
打包上線的問(wèn)題
這里只說(shuō)代碼上線之后和接口在同源情況下,如果不同源則存在跨域,這里先不考慮這種情況
假如我們把打包后的代碼也部署到了 'http://xxx.com:123'上
上線后的代碼為生產(chǎn)環(huán)境,沒有了proxy
那么他是怎么解析請(qǐng)求的呢?比如下面這個(gè)請(qǐng)求
axios.get('/scada/json/aa.tpl').then((res) => { //........
})
由于 '/'表示的是根目錄的意思,所以會(huì)解析為hostname + port + 請(qǐng)求的地址,即為 ‘http://xxx.com:123/scada/json/aa.tpl' ,沒有一點(diǎn)問(wèn)題,接口肯定能請(qǐng)求到
那么如果按照上面我說(shuō)的假設(shè)一或者假設(shè)二的寫法呢?
是不是會(huì)解析為 ‘http://xxx.com:123/scada/scada/json/aa.tpl' 和 ‘http://xxx.com:123/api/scada/scada/json/aa.tpl'
所以,假設(shè)一和假設(shè)二需要在打包之前修改請(qǐng)求地址才能打包,增加了許多不必要的麻煩
以上這篇webpack+vue-cil 中proxyTable配置接口地址代理操作就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
vue和webpack打包項(xiàng)目相對(duì)路徑修改的方法
這篇文章主要介紹了vue和webpack打包項(xiàng)目相對(duì)路徑修改的方法,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-06-06VueJS組件之間通過(guò)props交互及驗(yàn)證的方式
本篇文章主要介紹了VueJS組件之間通過(guò)props交互及驗(yàn)證的方式,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下。2017-09-09Vue.js基礎(chǔ)指令實(shí)例講解(各種數(shù)據(jù)綁定、表單渲染大總結(jié))
這篇文章主要為大家詳細(xì)介紹了Vue.js基礎(chǔ)指令實(shí)例,各種數(shù)據(jù)綁定、表單渲染大總結(jié),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-07-07axios請(qǐng)求的一些常見操作實(shí)戰(zhàn)指南
axios是一個(gè)輕量的HTTP客戶端,它基于XMLHttpRequest服務(wù)來(lái)執(zhí)行 HTTP請(qǐng)求,支持豐富的配置,支持Promise,支持瀏覽器端和 Node.js 端,下面這篇文章主要給大家介紹了關(guān)于axios請(qǐng)求的一些常見操作,需要的朋友可以參考下2022-09-09vue項(xiàng)目開啟gzip壓縮功能簡(jiǎn)單實(shí)例
這篇文章主要給大家介紹了關(guān)于vue項(xiàng)目開啟gzip壓縮功能的相關(guān)資料,gizp壓縮是一種http請(qǐng)求優(yōu)化方式,通過(guò)減少文件體積來(lái)提高加載速度,文中通過(guò)示例代碼介紹的非常詳細(xì),需要的朋友可以參考下2023-07-07Vue3 響應(yīng)式數(shù)據(jù) reactive使用方法
這篇文章主要介紹了Vue3 響應(yīng)式數(shù)據(jù) reactive使用方法,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2023-11-11npm run dev報(bào)錯(cuò)信息及解決方法
這篇文章主要為大家介紹了npm run dev報(bào)錯(cuò)信息及解決方法,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-09-09如何在Vue項(xiàng)目中應(yīng)用TypeScript類
與如何在React項(xiàng)目中應(yīng)用TypeScript類類似在VUE項(xiàng)目中應(yīng)用typescript,我們需要引入一個(gè)庫(kù)vue-property-decorator,需要的小伙伴可續(xù)看下文具體介紹2021-09-09