亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Vue腳手架配置代理服務(wù)器的兩種方式(小結(jié))

 更新時間:2023年01月08日 15:10:03   作者:小花皮豬  
本文主要介紹了Vue腳手架配置代理服務(wù)器的兩種方式(小結(jié)),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧

1 前言

本文主要介紹使用Vue腳手架配置代理服務(wù)器的兩種方式

注意:Vue腳手架給我們提供了兩種配置代理服務(wù)器的方式,各有千秋,使用的時候只能二選一,不能同時使用

2 代理

除了cros和jsonp,還有一種代理方式,這種用的相對來說也很多, 一般代理服務(wù)器

這個概念很好理解,相當于生活中的中介

在前后端直接配置一個代理服務(wù)器,這個代理服務(wù)器和前端處于一個位置,當前端向后端請求數(shù)據(jù)的時候,不會直接訪問后端,而是找這臺代理,代理收到前端的請求,轉(zhuǎn)發(fā)給后端,如果收到后端的響應(yīng)數(shù)據(jù),就把這些數(shù)據(jù)返回給前端

代理服務(wù)器的方式有一個東西大家應(yīng)該都聽說過:nginx,但是nginx一般屬于后端人員掌握的,這里使用一種對前端人員更加友好的技術(shù):cli,沒錯,就是vue的腳手架,它就可以幫助我們代理服務(wù)器,相比nginx它簡單的不能再簡單了,只需要短短幾行代碼就可以搞定

vue腳手架配置方式1

既然想對腳手架進行配置,肯定要改一個文件,就是vue的配置文件:vue.config.js,肯定要在這里面寫代碼,然后代理服務(wù)器就開起來了,到底怎么寫,可以參考官方文檔:Vue腳手架代理

復制配置代碼進行修改配置文件

注意:這里的端口是要請求后端的端口,并且只需要寫到端口即可,我的后端端口是9090

// 開啟代理服務(wù)器
devServer: {
  // 代理的端口是要請求后端的端口  寫到具體的端口即可 不需要寫具體的路徑
  proxy: 'http://localhost:9090'
}

注意:這種代理簡單,但是不完美,原因在下面

這樣就配置了一個代理服務(wù)器,一定要重啟腳手架

重啟完成后再次訪問,還是報錯跨域問題!

注意:雖然已經(jīng)配置了代理服務(wù)器,但是還沒用到這個代理,所以請求的時候不應(yīng)該是后端的端口9090,而是代理的端口8080,這里就要寫全路徑了,不能和配置代理服務(wù)器的時候一樣只寫端口了

再次訪問,發(fā)現(xiàn)正常了,說明代理有效

這種代理有兩個誤區(qū)(坑),下面一一說明

兩個誤區(qū)(坑)

誤區(qū)1

不能靈活的控制到底走不走代理

首先,這種代理不是什么都會代理給后端的,如果代理的東西前端有,就會直接返回,就不去找后端,比如下面這個例子

我在public目錄寫一個叫queryUserInfo的文件,沒錯,和后端的接口名稱一樣

這時候請求就會發(fā)現(xiàn),找到前端的內(nèi)容就不會訪問后端了

誤區(qū)2

這種代理只能代理一個服務(wù)器不能代理多個服務(wù)器,也就是說目前代理的8080只能把請求交給9090,不能轉(zhuǎn)發(fā)給別人了

vue腳手架配置方式2

上面的代理方式,雖然簡單,但是也有兩個坑,不夠完美,想要追求完美,還得是這種方式

那么這種方式怎么寫呢?還是繼續(xù)看官方文檔:Vue腳手架代理

注意:這種配置代理和上面的配置代理只能二選一,不能同時使用!

把代碼復制到配置文件,進行修改

devServer: {<!--{cke_protected}{C}%3C!%2D%2D%20%2D%2D%3E-->proxy: {<!--{cke_protected}{C}%3C!%2D%2D%20%2D%2D%3E-->'/api': {<!--{cke_protected}{C}%3C!%2D%2D%20%2D%2D%3E-->target: '<url>',ws: true,changeOrigin: true},'/foo': {<!--{cke_protected}{C}%3C!%2D%2D%20%2D%2D%3E-->target: '<other_url>'}}}

這里面有一些屬性,有的屬性可以配置使用,我們一一說明

注意:不管修改哪個屬性,都要重啟vue!

/api和target

/api指的是請求前綴 這里的api可以更改 不一定非要叫api

target指的是如果請求前綴匹配上了,那么就找代理服務(wù)器請求

比如現(xiàn)在我請求的路徑不變還是上面的路徑

那么還是一樣的效果

這時候我把api前綴加上,理論來說可以了,但是還是不行

不過這次不是跨域的問題了,只是找不到請求

找不到請求是對的,因為的后端請求沒有/api的前綴,那么如果忽略這個前綴呢?

pathRewrite

有這么一個屬性,官方?jīng)]有說:pathRewrite

         // 忽略前綴路徑 它是一個對象 里面是key value
        // 這個正則意思是 如果前綴是/api,那么會替換成空字符
      pathRewrite:{'^/api':''}

這個時候再測試,發(fā)現(xiàn)正常

ws

ws是websocket的縮寫,用于支持websocket,默認為true,本人對websocket不是很了解,所以不多敘述!

changeOrigin

用于控制請求頭中的host值

或者說是否真實匯報自身情況 true不真實 false真實 一般為true,默認也是true

為什么這么說呢?我們通過下面案例查看,這時候我后端獲取請求的主機信息,大家注意觀察

改為false,好家伙,你小子反水是吧

配置多個代理

如果想要配置多個代理,直接復制一個即可,注意加上逗號,修改端口和前綴

3 vue腳手架配置代理總結(jié)

vue腳手架配置代理
方法一
在vue.config.js中添加如下配置:
devServer:{
  proxy:"http://localhost:5000"
}
說明:
1. 優(yōu)點:配置簡單,請求資源時直接發(fā)給前端(8080)即可。
2. 缺點:不能配置多個代理,不能靈活的控制請求是否走代理。
3. 工作方式:若按照上述配置代理,當請求了前端不存在的資源時,那么該請求會轉(zhuǎn)發(fā)給服務(wù)器 (優(yōu)先匹配前端資源)
方法二
編寫vue.config.js配置具體代理規(guī)則:
module.exports = {
    devServer: {
      proxy: {
      '/api1': {// 匹配所有以 '/api1'開頭的請求路徑
        target: 'http://localhost:5000',// 代理目標的基礎(chǔ)路徑
        changeOrigin: true,
        pathRewrite: {'^/api1': ''}
      },
      '/api2': {// 匹配所有以 '/api2'開頭的請求路徑
        target: 'http://localhost:5001',// 代理目標的基礎(chǔ)路徑
        changeOrigin: true,
        pathRewrite: {'^/api2': ''}
      }
    }
  }
}
/*
   changeOrigin設(shè)置為true時,服務(wù)器收到的請求頭中的host為:localhost:5000
   changeOrigin設(shè)置為false時,服務(wù)器收到的請求頭中的host為:localhost:8080
   changeOrigin默認值為true
*/
說明:
1. 優(yōu)點:可以配置多個代理,且可以靈活的控制請求是否走代理。
2. 缺點:配置略微繁瑣,請求資源時必須加前綴。

到此這篇關(guān)于Vue腳手架配置代理服務(wù)器的兩種方式(小結(jié))的文章就介紹到這了,更多相關(guān)Vue腳手架配置代理服務(wù)器內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • vue3中的透傳attributes教程示例詳解

    vue3中的透傳attributes教程示例詳解

    這篇文章主要為大家介紹了vue3中的透傳attributes教程示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-08-08
  • Vue組件選項props實例詳解

    Vue組件選項props實例詳解

    父組件通過 props 向下傳遞數(shù)據(jù)給子組件,子組件通過 events 給父組件發(fā)送消息。本文將詳細介紹Vue組件選項props,需要的朋友可以參考下
    2017-08-08
  • 淺談Vue組件及組件的注冊方法

    淺談Vue組件及組件的注冊方法

    本文主要介紹了淺談Vue組件及組件的注冊方法,詳細的介紹了什么是組件,及其組件注冊的兩種方式(全局和局部),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-08-08
  • Vue+Element實現(xiàn)封裝抽屜彈框

    Vue+Element實現(xiàn)封裝抽屜彈框

    這篇文章主要為大家詳細介紹了如何利用Vue和Element實現(xiàn)簡單的抽屜彈框效果,文中的示例代碼講解詳細,感興趣的小伙伴可以跟隨小編一起學習一下
    2023-06-06
  • 淺談vue中數(shù)據(jù)雙向綁定的實現(xiàn)原理

    淺談vue中數(shù)據(jù)雙向綁定的實現(xiàn)原理

    本篇文章主要介紹了淺談vue中數(shù)據(jù)雙向綁定的實現(xiàn)原理 ,主要使用v-model這個數(shù)據(jù)雙向綁定,有興趣的可以了解一下
    2017-09-09
  • vue動態(tài)生成新表單并且添加驗證校驗規(guī)則方式

    vue動態(tài)生成新表單并且添加驗證校驗規(guī)則方式

    這篇文章主要介紹了vue動態(tài)生成新表單并且添加驗證校驗規(guī)則方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-10-10
  • Vue項目接入Paypal實現(xiàn)示例詳解

    Vue項目接入Paypal實現(xiàn)示例詳解

    這篇文章主要介紹了Vue項目接入Paypal實現(xiàn)示例詳解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-06-06
  • ElementUI時間選擇器限制選擇范圍disabledData的使用

    ElementUI時間選擇器限制選擇范圍disabledData的使用

    本文主要介紹了ElementUI時間選擇器限制選擇范圍disabledData的使用,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2022-06-06
  • Vuex的基本概念、項目搭建以及入坑點

    Vuex的基本概念、項目搭建以及入坑點

    Vuex是一個專門為Vue.js應(yīng)用程序開發(fā)的狀態(tài)管理模式,這篇文章主要介紹了Vuex的基本概念、項目搭建以及入坑點,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-11-11
  • axios中如何進行同步請求(async+await)

    axios中如何進行同步請求(async+await)

    這篇文章主要介紹了axios中如何進行同步請求(async+await),具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-09-09

最新評論