欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

vue項目打包后proxyTable代理失效問題及解決

 更新時間:2023年05月18日 10:15:02   作者:Sca_杰  
這篇文章主要介紹了vue項目打包后proxyTable代理失效問題及解決方案,具有很好的參考價值,希望對大家有所幫助。

vue項目打包后proxyTable代理失效

原因

在vue.config.js中配置了proxy跨域后執(zhí)行npm run build打包部署到服務器上會報跨域問題,為什么會報錯呢?因為編譯打包后,前端頁面成為了單獨的靜態(tài)資源,代理服務器devServer.proxy被抽離出去了。

也就是說,devServer.proxy不會一起打包到dist文件夾下,所以相當于我們沒有配置代理服務器!!

怎么解決呢?資源要被訪問,那必須要有一個代理服務器來裝載它。我們部署上線最常見的就是使用nginx進行反向代理,只需要修改nginx配置文件即可。

解決方案

示例如下:

第一步、找到項目的配置文件。

第二步、在其中添加下面這段代碼,根據(jù)自己實際情況修改即可:

location /api{
        rewrite ^.+api/?(.*)$ /$1 break;    
        //可選參數(shù),正則驗證地址
        include uwsgi_params;    
        //可選參數(shù),uwsgi是服務器和服務端應用程序的通信協(xié)議,規(guī)定了怎么把請求轉(zhuǎn)發(fā)給應用程序和返回
        proxy_pass http://www.test.com;    
        // 接口地址
}

vue使用proxyTable實現(xiàn)多重跨域

眾所周知,vue跨域有很多種解決方案,這里主要講述一下使用proxyTable時遇到的一些問題

  • vue環(huán)境:腳手架cli3.0
  • 本地地址:http://localhost:96
  • 修改文件:vue.config.js
module.exports = {
? ? devServer: {
? ? ? ? proxy: {
? ? ? ? ? ? 'aaa': { //跨域標識
?? ??? ??? ??? ?target: 'http://www.aaa.com/', //跨域地址
? ? ? ? ? ? ? ? changeOrigin: true, //是否允許跨域
? ? ? ? ? ? ? ? pathRewrite: {
? ? ? ? ? ? ? ? ? ? '^/aaa': '' //跨域地址重寫
? ? ? ? ? ? ? ? }
? ? ? ? ? ? },
? ? ? ? ? ? 'bbb': { //跨域標識
?? ??? ??? ??? ?target: 'http://www.bbb.com/', //跨域地址
? ? ? ? ? ? ? ? changeOrigin: true, //是否允許跨域
? ? ? ? ? ? ? ? pathRewrite: {
? ? ? ? ? ? ? ? ? ? '^/bbb': '' //跨域地址重寫
? ? ? ? ? ? ? ? }
? ? ? ? ? ? },
? ? ? ? },
? ? },
}

跨域標識:跨域配置的基本標識,必填,可自定義

  • 使用 axios.get('/aaa/api/getuser') 時,真實的請求地址就是http://www.aaa.com/api/getuser
  • 使用 axios.get('/bbb/api/getuser') 時,真實的請求地址就是http://www.bbb.com/api/getuser

pathRewrite: '^/aaa': ''冒號前面的字母必須跟跨域標識一致,否則跨域失敗,后面的內(nèi)容可以自定義

  • '^/aaa': ''為空時,真實的請求地址為http://www.aaa.com/api/getuser
  • '^/aaa': 'zdy'不為空時,真實的請求地址為http://www.aaa.com/zdy/api/getuser

有一點需要注意,不管怎么設(shè)置,我們在瀏覽器控制臺里看到的請求地址還是http://localhost:96/aaa/api/getuser

那么問題來了,我們在使用腳手架開發(fā)時,會涉及到一個開發(fā)環(huán)境和生產(chǎn)環(huán)境的全局配置

axios.defaults.baseURL = process.env.NODE_ENV === 'production' ? '/' : '/aaa';

這段代碼的含義是當處于開發(fā)環(huán)境時,使用axios.get('/api/getuser')時等于在地址前面加上’/aaa‘變成axios.get('/aaa/api/getuser') ,由于這是全局配置,不能去修改,所以我們想要跨域請求www.bbb.com時使如果用axios.get('bbb/api/getuser'),那真實地址會變成http://www.aaa.com/bbb/api/getuser,解決代碼如下

module.exports = {
? ? devServer: {
? ? ? ? proxy: {
? ? ? ? ? ? 'aaa/bbb': { //跨域標識
?? ??? ??? ??? ?target: 'http://www.bbb.com/', //跨域地址
? ? ? ? ? ? ? ? changeOrigin: true, //是否允許跨域
? ? ? ? ? ? ? ? pathRewrite: {
? ? ? ? ? ? ? ? ? ? '^/aaa/bbb': '' //跨域地址重寫
? ? ? ? ? ? ? ? }
? ? ? ? ? ? },
? ? ? ? ? ? 'aaa': { //跨域標識
?? ??? ??? ??? ?target: 'http://www.aaa.com/', //跨域地址
? ? ? ? ? ? ? ? changeOrigin: true, //是否允許跨域
? ? ? ? ? ? ? ? pathRewrite: {
? ? ? ? ? ? ? ? ? ? '^/aaa': '' //跨域地址重寫
? ? ? ? ? ? ? ? }
? ? ? ? ? ? },
? ? ? ? },
? ? },
}

因為存在全局配置axios.defaults.baseURL = process.env.NODE_ENV === 'production' ? '/' : '/aaa';那么

  • 使用 axios.get('/api/getuser') 時會變成axios.get('aaa/api/getuser') ,因為存在’aaa‘,程序會執(zhí)行第二個配置,真實的請求地址就是http://www.aaa.com/api/getuser
  • 使用 axios.get('/bbb/api/getuser') 時會變成axios.get('aaa/bbb/api/getuser') ,因為存在’aaa/bbb‘,程序會執(zhí)行第一個配置,真實的請求地址就是http://www.bbb.com/api/getuser

需要注意的的是兩個配置的順序不能改,因為代碼的執(zhí)行順序是由上而下的,如果’aaa‘放在上面,'aaa/bbb'在下面,那么使用

axios.get('/bbb/api/getuser')時程序就會判斷第一個配置符合條件然后執(zhí)行第一個配置變成axios.get('aaa/bbb/api/getuser'),最終真實請求地址還是http://www.aaa.com/bbb/api/getuser

以上代碼都是建立在本地環(huán)境的基礎(chǔ)上,打包上線后則需要使用nginx配合了。 

總結(jié)

這些僅為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • vue中自定義組件雙向綁定的三種方法總結(jié)

    vue中自定義組件雙向綁定的三種方法總結(jié)

    這篇文章主要介紹了vue中自定義組件雙向綁定的三種方法總結(jié),具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-06-06
  • 基于ant design日期控件使用_僅月份的操作

    基于ant design日期控件使用_僅月份的操作

    這篇文章主要介紹了基于ant design日期控件使用_僅月份的操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-10-10
  • Vue注冊組件命名時不能用大寫的原因淺析

    Vue注冊組件命名時不能用大寫的原因淺析

    這段時間一直在弄vue,當然也遇到很多問題,這里就來跟大家分享一些注冊自定義模板組件的心得 ,需要的朋友可以參考下
    2019-04-04
  • JSON數(shù)組和JSON對象在vue中的獲取方法

    JSON數(shù)組和JSON對象在vue中的獲取方法

    這兩天在學習vue,主要是為了實現(xiàn)前后端的分離,因此數(shù)據(jù)的傳輸是必不可少的一個環(huán)節(jié),這篇文章主要介紹了JSON數(shù)組和JSON對象在vue中的獲取方法,需要的朋友可以參考下
    2022-09-09
  • 解決vue中reader.onload讀取文件的異步問題

    解決vue中reader.onload讀取文件的異步問題

    這篇文章主要介紹了解決vue中reader.onload讀取文件的異步問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-10-10
  • 在vue中高德地圖引入和軌跡的繪制的實現(xiàn)

    在vue中高德地圖引入和軌跡的繪制的實現(xiàn)

    這篇文章主要介紹了在vue中高德地圖引入和軌跡的繪制的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2019-10-10
  • vue data變量相互賦值后被實時同步的解決步驟

    vue data變量相互賦值后被實時同步的解決步驟

    這篇文章主要介紹了vue data變量相互賦值后被實時同步的解決步驟,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-08-08
  • vue實現(xiàn)組件之間傳值功能示例

    vue實現(xiàn)組件之間傳值功能示例

    這篇文章主要介紹了vue實現(xiàn)組件之間傳值功能,結(jié)合實例形式分析了vue.js父子組件之間相互傳值常見操作技巧,需要的朋友可以參考下
    2018-07-07
  • Vue之組件的自定義事件詳解

    Vue之組件的自定義事件詳解

    這篇文章主要為大家介紹了Vue之組件的自定義事件,具有一定的參考價值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
    2021-11-11
  • Vue代碼分割懶加載的實現(xiàn)方法

    Vue代碼分割懶加載的實現(xiàn)方法

    這篇文章主要給大家介紹了關(guān)于Vue代碼分割懶加載的實現(xiàn)方法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧。
    2017-11-11

最新評論