React開啟代理的2種實用方式

開啟代理的兩種方式

react並沒有封裝好瞭的ajax請求的代碼供我們直接使用,在進行交互的時候,我們需要自己封裝ajax代碼或者使用第三方ajax庫,一般我們用axios(輕量級)。

先說一下為什麼需要代理?

比如說,在本地寫一個端口為5000的服務器時,當我們通過端口3000去發生請求,會出現跨域的問題(原來3000端口的ajax引擎把響應攔截瞭),此時可以通過代理來解決問題。所謂的代理就是一個傳遞信息的工具,端口為3000的請求發給開在3000端口的代理,代理再轉發給5000端口的服務器,在響應的時候,由於代理是沒有ajax引擎的代理,所以可以接收響應,再傳遞給開在3000端口的腳手架,從而解決瞭跨域的問題。

react開啟代理的兩種方式

方法一

在package.json文件中添加”proxy”: “https://localhost:5000” 配置之後3000端口沒有的資源就會去端口5000找。也就是說會把把發給端口為3000的請求轉發給開在端口5000的服務器,但是如果請求的東西再端口3000中已經有瞭的話就不會再轉發到端口5000裡面找瞭。

這種方法隻能找一個,但是如果你不隻是要再端口5000中找,還想在其它端口號找的話(配置多個代理),就要用下面這個方法瞭。

方法二

在src中添加一個setupProxy的文件(react腳手架會找到這個文件),復制如下代碼

配置之後需要在之前發送請求的地址localhost:3000後加/api1,表示如果在3000端口沒有找到請求所要的資源,就去api1所配置的代理,於是就去訪問端口5000。如果想要配置多個代理,用逗號隔開即可。

changeOrigin用於控制服務器收到的響應頭中Host字段的值。在這裡,如果時默認值值,為false的話,服務器會以為這個請求時來自於端口為3000;但如果把它的值設置為true,此時服務器會認為這個請求時來自於端口5000的(其實不是)。這個可以不寫但是最好寫上。

pathWrite時重寫瞭請求路徑,其實就是剛開始通過/api找到瞭這個代理,但是當代理向端口5000發生請求的時候要把/api去掉,比如https://localhost:3000/api/student,如果沒有把api去掉就相當於請求地址為/api/students,但實際上我們要請求的地址應該是/student。

const proxy = require('http-proxy-middleware');
​
module.exports = function (app) {
    app.use(
        proxy('/api1', {
            target: 'http://localhost:5000',  
            changeOrigin: true,      // 默認值是false
            pathRewrite: { '^/api1': '' }  
        }),
        proxy('/api2', {
            target: 'http://localhost:5001',
            changeOrigin: true,      // 默認值是false
            pathRewrite: { '^/api2': '' }
        }),
    )
}

總結

到此這篇關於React開啟代理的2種方式的文章就介紹到這瞭,更多相關React開啟代理方式內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!

推薦閱讀: