webpack+vue-cil 中proxyTable配置接口地址代理操作
在項目開發(fā)的時候,接口聯(lián)調(diào)的時候一般都是同域名下,且不存在跨域的情況下進行接口聯(lián)調(diào),但是當我們現(xiàn)在使用vue-cli進行項目打包的時候,我們在本地啟動服務(wù)器后,比如本地開發(fā)服務(wù)下是 http://localhost:8080 這樣的訪問頁面,但是我們的接口地址是 http://xxxx.com/save/index 這樣的接口地址,我們這樣直接使用會存在跨域的請求,導(dǎo)致接口請求不成功,因此我們需要在打包的時候配置一下,我們進入 config/index.js 代碼下如下配置即可:
dev: {
// 靜態(tài)資源文件夾
assetsSubDirectory: 'static',
// 發(fā)布路徑
assetsPublicPath: '/',
// 代理配置表,在這里可以配置特定的請求代理到對應(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接口,需要配置這個參數(shù)
changeOrigin: true, // 如果接口跨域,需要進行這個參數(shù)配置
pathRewrite: {
'^/api': ''
}
}
},
// 本地訪問 http://localhost:8080
host: 'localhost', // can be overwritten by process.env.HOST
接口地址原本是 /save/index,但是為了匹配代理地址,在前面加一個 /api, 因此接口地址需要寫成這樣的即可生效 /api/save/index。
注意: '/api' 為匹配項,target 為被請求的地址,因為在 ajax 的 url 中加了前綴 '/api',而原本的接口是沒有這個前綴的,所以需要通過 pathRewrite 來重寫地址,將前綴 '/api' 轉(zhuǎn)為 '/'。如果本身的接口地址就有 '/api' 這種通用前綴,就可以把 pathRewrite 刪掉。
補充知識:webpack -- 關(guān)于proxyTable的配置在開發(fā)環(huán)境和生產(chǎn)環(huán)境中的原理解析
前言
首先,proxyTable是我們在本地開發(fā)環(huán)境中調(diào)試接口用的,目的是為了解決本地跨域的問題,因為本地地址為localhost:xxxx/xxx
在線上的生產(chǎn)環(huán)境是沒用的?。?!
假設(shè)我們用的是vue-cli命令行工具生成的webpack項目模板,我們很容易能在config文件夾下面找到index.js文件。
本地如何配置
假設(shè)我要請求的地址為
'http://xxx.com/scada/json/aa.tpl'
我們在index.js文件中找到如下代碼:我推薦了一種寫法,后面我會說為什么
那么我請求的那段代碼就是這樣的
axios.get('/scada/json/aa.tpl').then((res) => {
//........
})
稍微解釋一下其中的原理:當發(fā)請求的時候,proxy就會起作用,他會在接口'/scada'前面加上 ‘http://xxx.com:123',成為 ‘http://xxx.com:123/scada/json/aa.tpl' 由于我們配置中的 pathRewrite字段需要將 '/scada'寫為 ‘/scada',所以請求接口還是 ‘http://xxx.com:123/scada/json/aa.tpl'
繼續(xù)向下看,干貨還在后面
假設(shè)幾種其它的寫法
假設(shè)一
如果proxyTable配置是這樣的
proxyTable: {
'/scada': {
target: 'http://xxx.com:123',
changeOrigin: true,
pathRewrite: {
'^/scada': '/'
}
}
那么我們的請求代碼必須寫成這樣
axios.get('/scada/scada/json/aa.tpl').then((res) => {
//........
//是不是有點難受
})
假設(shè)二
如果proxyTable配置是這樣的,也就是重新起個名字
proxyTable: {
'/api': {
target: 'http://xxx.com:123',
changeOrigin: true,
pathRewrite: {
'^/api': '/'
}
}
那么我們的請求代碼必須寫成這樣
axios.get('/api/scada/json/aa.tpl').then((res) => {
//........
//這種寫法還能接受,但是有個致命的缺點
})
再向下看,看看我推薦的寫法的真真優(yōu)勢
打包上線的問題
這里只說代碼上線之后和接口在同源情況下,如果不同源則存在跨域,這里先不考慮這種情況
假如我們把打包后的代碼也部署到了 'http://xxx.com:123'上
上線后的代碼為生產(chǎn)環(huán)境,沒有了proxy
那么他是怎么解析請求的呢?比如下面這個請求
axios.get('/scada/json/aa.tpl').then((res) => { //........
})
由于 '/'表示的是根目錄的意思,所以會解析為hostname + port + 請求的地址,即為 ‘http://xxx.com:123/scada/json/aa.tpl' ,沒有一點問題,接口肯定能請求到
那么如果按照上面我說的假設(shè)一或者假設(shè)二的寫法呢?
是不是會解析為 ‘http://xxx.com:123/scada/scada/json/aa.tpl' 和 ‘http://xxx.com:123/api/scada/scada/json/aa.tpl'
所以,假設(shè)一和假設(shè)二需要在打包之前修改請求地址才能打包,增加了許多不必要的麻煩
以上這篇webpack+vue-cil 中proxyTable配置接口地址代理操作就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
vue實現(xiàn)excel文件的導(dǎo)入和讀取完整步驟
Vue的數(shù)據(jù)綁定功能非常強大,很適合用來讀取Excel內(nèi)容,這篇文章主要給大家介紹了關(guān)于vue實現(xiàn)excel文件的導(dǎo)入和讀取的相關(guān)資料,文中通過代碼示例介紹的非常詳細,需要的朋友可以參考下2023-10-10
vue2 拖動排序 vuedraggable組件的實現(xiàn)
這篇文章主要介紹了vue2 拖動排序 vuedraggable組件的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-08-08
Vue的路由動態(tài)重定向和導(dǎo)航守衛(wèi)實例
下面小編就為大家分享一篇Vue的路由動態(tài)重定向和導(dǎo)航守衛(wèi)實例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-03-03

