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

vue.config.js中devServer.proxy配置說(shuō)明及配置正確不生效問(wèn)題解決

 更新時(shí)間:2023年02月13日 10:56:18   作者:cc_King  
Vue項(xiàng)目devServer.proxy代理配置詳解的是一個(gè)非常常見(jiàn)的需求,下面這篇文章主要給大家介紹了關(guān)于vue.config.js中devServer.proxy配置說(shuō)明及配置正確不生效問(wèn)題解決的相關(guān)資料,需要的朋友可以參考下

proxy 配置確認(rèn)、解析

devServer: {
    https: true, // 開(kāi)啟https模式
    // 配置服務(wù)器代理
    proxy: {
      '/api': { // 匹配訪問(wèn)路徑中含有 '/api' 的路徑
        target: 'http://localhost:3000/', // 測(cè)試地址、目標(biāo)地址
        changeOrigin: true,
        ws: true, // 是否開(kāi)啟 webSocket 代理
        pathRewrite: { // 請(qǐng)求路徑重寫(xiě)
          '^/api': '',   //重寫(xiě)請(qǐng)求路徑
        },
      }
    }
  },

原因 一

百度最多的解釋

  • 配置寫(xiě)錯(cuò)了 (解決:復(fù)制粘貼上面的實(shí)例下去改)
  • 路徑?jīng)]有匹配上 (解決:看本文的詳解部分)

原因二

這個(gè)原因得注意一下

  • 方式是給我們開(kāi)發(fā)環(huán)境用的 ,其次是我們的請(qǐng)求要被開(kāi)發(fā)服務(wù)器接收到,且不能匹配到請(qǐng)求,然后我們的請(qǐng)求就會(huì)被代理到配置的URL。
  • 注釋掉,或者改為本地路徑,否則代理不會(huì)生效

比如說(shuō)我之前的全局 http.js 配置文件是這樣寫(xiě)的

const http = axios.create({
  baseURL: 'http://localhost:3000/',
})

所以不論是 生產(chǎn) 還是 開(kāi)發(fā) 環(huán)境下,我的請(qǐng)求都會(huì)發(fā)送給我們配置的baseURL,而不會(huì)走我們的代理?。。?。

所以我們得修改一下配置,使我們的生產(chǎn)路徑在生產(chǎn)環(huán)境下才生效

let baseURL = "/";
if (process.env.NODE_ENV === 'production') {
  baseURL = 'http://localhost:3000/';
}

const http = axios.create({
  baseURL,
})

這樣在開(kāi)發(fā)環(huán)境下,我們的 baseURL = "/", 代理就可以生效了。

注意

  • 還有一點(diǎn)就是,即使我們的代理生效了,但是在瀏覽器請(qǐng)求頭中展示的也不是配置的代理地址;
  • 所以測(cè)的時(shí)候得多問(wèn)問(wèn)后端請(qǐng)求過(guò)去沒(méi)有,或者自己node搭個(gè)簡(jiǎn)易的服務(wù)器看看成沒(méi)成功;
  • 不要一根筋的死盯瀏覽器的請(qǐng)求頭地址。

詳解

請(qǐng)求路徑必須帶有標(biāo)識(shí)?。?!

proxy: {
      '/api': { 
      ...
      }
 }
  • 用代理首先你得有一個(gè)標(biāo)識(shí),表明你的這個(gè)連接要使用代理;
  • 不然的話 html css js 這些靜態(tài)資源都跑去代理。
  • /api 就是告訴 node ,我接口用 /api 開(kāi)頭的才使用代理,所以接口都寫(xiě)成 /api/xx/xx
  • 出現(xiàn)問(wèn)題: 請(qǐng)求路徑?jīng)]有 /api ,使用 pathRewrite 解決

pathRewrite

pathRewrite: { // 請(qǐng)求路徑重寫(xiě)
    '^/api': '',   //重寫(xiě)請(qǐng)求路徑
 },

pathRewrite的key值 ^/api 就是一個(gè)正則表達(dá)式。

pathRewrite的value值 為替換后的路徑。

這里的話就是將匹配成功的地址當(dāng)做一個(gè)字符串,然后執(zhí)行 js 的 replace 方法,將執(zhí)行成功的最終結(jié)果作為最后的請(qǐng)求路徑。

  • 比如:
  • 我們有一個(gè)請(qǐng)求 axios.get("/api/aa/bb/cc") ;
  • 根據(jù)我們這里配置的 proxy, 帶有 /api 的請(qǐng)求路徑就需要進(jìn)行代理,且 /api/aa/bb/cc 路徑中含有 /api ,所以該請(qǐng)求就需要代理。
  • 將路徑當(dāng)做字符串執(zhí)行, "/api/aa/bb/cc".replace(/^\/api/, "")
  • 執(zhí)行結(jié)果: /aa/bb/cc
  • 最終的請(qǐng)求路徑變成了 http://localhost:3000/aa/bb/cc 不含/api;

axios.get("/ee/ff/dd") 這個(gè)請(qǐng)求就不會(huì)進(jìn)行代理,因?yàn)槠ヅ洳簧衔覀冾A(yù)設(shè)的規(guī)則 (請(qǐng)求路徑?jīng)]有 /api

最終的請(qǐng)求路徑變成了 http://localhost:3000/ee/ff/dd, 和原路徑一致;

又比如說(shuō)我們的配置為

pathRewrite: { // 請(qǐng)求路徑重寫(xiě)
    '^/api': '/rewrite',   //重寫(xiě)請(qǐng)求路徑
 }
  • 那么我們的請(qǐng)求 axios.get("/api/aa/bb/cc") ;
  • 會(huì)執(zhí)行 "/api/aa/bb/cc".replace(/^\/api/, "/rewrite");
  • 最終的請(qǐng)求路徑變成了 http:/rewrite/localhost:3000//aa/bb/cc;
  • 將 /rewrite 替換了開(kāi)頭的/api。

changeOrigin

假設(shè),如果你的前端服務(wù)器是 http://localhost:3000,后端是 http://localhost:8082。

那么后端通過(guò) request.getHeader(“Host”) 獲取依舊是 http://localhost:3000。

如果你設(shè)置了 changeOrigin: true,那么后端通過(guò) request.getHeader(“Host”) 獲取才是 http://localhost:8082。代理服務(wù)器此時(shí)會(huì)根據(jù)請(qǐng)求的 target 地址修改 Host。

總結(jié)

到此這篇關(guān)于vue.config.js中devServer.proxy配置說(shuō)明及配置正確不生效問(wèn)題解決的文章就介紹到這了,更多相關(guān)vue.config.js中devServer.proxy配置說(shuō)明內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Vue表單控件綁定圖文詳解

    Vue表單控件綁定圖文詳解

    在本文中我們給大家整理了一篇關(guān)于Vue表單控件綁定的相關(guān)知識(shí)點(diǎn)內(nèi)容,有需要的朋友們參考下。
    2019-02-02
  • vue3?setup語(yǔ)法糖中獲取slot插槽的dom對(duì)象代碼示例

    vue3?setup語(yǔ)法糖中獲取slot插槽的dom對(duì)象代碼示例

    slot元素是一個(gè)插槽出口,標(biāo)示了父元素提供的插槽內(nèi)容將在哪里被渲染,這篇文章主要給大家介紹了關(guān)于vue3?setup語(yǔ)法糖中獲取slot插槽的dom對(duì)象的相關(guān)資料,文中通過(guò)代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2024-04-04
  • 基于Vue.js的表格分頁(yè)組件

    基于Vue.js的表格分頁(yè)組件

    這篇文章主要為大家詳細(xì)介紹了基于Vue.js的表格分頁(yè)組件使用方法,了解了Vue.js的特點(diǎn),感興趣的朋友可以參考一下
    2016-05-05
  • 使用idea創(chuàng)建第一個(gè)Vue項(xiàng)目

    使用idea創(chuàng)建第一個(gè)Vue項(xiàng)目

    最近在學(xué)習(xí)vue,本文主要介紹了使用idea創(chuàng)建第一個(gè)Vue項(xiàng)目,文中根據(jù)圖文介紹的十分詳盡,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-03-03
  • Vue-cli 移動(dòng)端布局和動(dòng)畫(huà)使用詳解

    Vue-cli 移動(dòng)端布局和動(dòng)畫(huà)使用詳解

    這篇文章主要介紹了Vue-cli和移動(dòng)端布局和動(dòng)畫(huà)使用詳解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2020-08-08
  • 淺談vue-cli5關(guān)于yarn的一個(gè)小坑

    淺談vue-cli5關(guān)于yarn的一個(gè)小坑

    本文主要介紹了vue-cli5關(guān)于yarn的一個(gè)小坑,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2022-05-05
  • vue中關(guān)于v-for循環(huán)key值問(wèn)題的研究

    vue中關(guān)于v-for循環(huán)key值問(wèn)題的研究

    這篇文章主要介紹了vue中關(guān)于v-for循環(huán)key值問(wèn)題的研究,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-06-06
  • Vue3使用Echarts導(dǎo)致tooltip失效問(wèn)題及解決方法

    Vue3使用Echarts導(dǎo)致tooltip失效問(wèn)題及解決方法

    Vue3 使用 proxy 對(duì)象代理,而 echarts 則使用了大量的全等(===), 對(duì)比失敗從而導(dǎo)致了bug,這篇文章主要介紹了Vue3使用Echarts導(dǎo)致tooltip失效問(wèn)題及解決方法,需要的朋友可以參考下
    2023-08-08
  • 解決vue跨域axios異步通信問(wèn)題

    解決vue跨域axios異步通信問(wèn)題

    這篇文章主要介紹了解決vue跨域axios異步通信問(wèn)題,非常不錯(cuò),具有一定的參考借鑒價(jià)值 ,需要的朋友可以參考下
    2019-04-04
  • vue-router的使用方法及含參數(shù)的配置方法

    vue-router的使用方法及含參數(shù)的配置方法

    這篇文章主要介紹了vue-router的使用方法及含參數(shù)的配置方法,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2018-11-11

最新評(píng)論