React?腳手架配置代理完整指南(最新推薦)
React 腳手架配置代理完整指南
1. 代理配置方式概述
React 腳手架中配置代理主要有以下幾種方式:
- 在 package.json 中配置簡(jiǎn)單代理
- 在 src/setupProxy.js 中配置復(fù)雜代理
- 使用 nginx 反向代理
- 使用環(huán)境變量配置代理
2. 基礎(chǔ)配置方法
2.1 package.json 簡(jiǎn)單配置
{
"name": "my-app",
"version": "0.1.0",
"private": true,
"proxy": "http://localhost:5000"
}這種方式的特點(diǎn):
- 優(yōu)點(diǎn):配置簡(jiǎn)單
- 缺點(diǎn):只能配置單個(gè)代理
- 適用場(chǎng)景:只需要代理到單個(gè)接口服務(wù)器
2.2 setupProxy.js 配置
// src/setupProxy.js
const { createProxyMiddleware } = require('http-proxy-middleware');
module.exports = function(app) {
app.use(
'/api',
createProxyMiddleware({
target: 'http://localhost:5000',
changeOrigin: true,
pathRewrite: {
'^/api': ''
}
})
);
app.use(
'/api2',
createProxyMiddleware({
target: 'http://localhost:5001',
changeOrigin: true,
pathRewrite: {
'^/api2': ''
}
})
);
};這種方式的特點(diǎn):
- 優(yōu)點(diǎn):可以配置多個(gè)代理,更靈活
- 缺點(diǎn):配置相對(duì)復(fù)雜
- 適用場(chǎng)景:需要代理到多個(gè)服務(wù)器
3. 高級(jí)配置示例
3.1 帶身份驗(yàn)證的代理
// src/setupProxy.js
const { createProxyMiddleware } = require('http-proxy-middleware');
module.exports = function(app) {
app.use(
'/api',
createProxyMiddleware({
target: 'http://localhost:5000',
changeOrigin: true,
onProxyReq: function(proxyReq, req, res) {
// 添加自定義請(qǐng)求頭
proxyReq.setHeader('Authorization', 'Bearer your-token');
},
onProxyRes: function(proxyRes, req, res) {
// 處理響應(yīng)頭
proxyRes.headers['x-proxy-by'] = 'your-app';
}
})
);
};3.2 帶路徑重寫(xiě)的代理
// src/setupProxy.js
const { createProxyMiddleware } = require('http-proxy-middleware');
module.exports = function(app) {
app.use(
'/api',
createProxyMiddleware({
target: 'http://localhost:5000',
changeOrigin: true,
pathRewrite: {
'^/api/old-path': '/api/new-path', // 重寫(xiě)路徑
'^/api/remove': '' // 刪除路徑
},
router: {
// 根據(jù)請(qǐng)求路徑改變目標(biāo)服務(wù)器
'dev.localhost:3000': 'http://localhost:8000',
'staging.localhost:3000': 'http://localhost:9000'
}
})
);
};3.3 帶負(fù)載均衡的代理
// src/setupProxy.js
const { createProxyMiddleware } = require('http-proxy-middleware');
// 定義目標(biāo)服務(wù)器列表
const targets = [
'http://localhost:5000',
'http://localhost:5001',
'http://localhost:5002'
];
let currentIndex = 0;
module.exports = function(app) {
app.use(
'/api',
createProxyMiddleware({
target: targets[0],
changeOrigin: true,
router: () => {
// 簡(jiǎn)單的輪詢(xún)負(fù)載均衡
currentIndex = (currentIndex + 1) % targets.length;
return targets[currentIndex];
}
})
);
};4. 環(huán)境變量配置
4.1 創(chuàng)建環(huán)境變量文件
# .env.development REACT_APP_API_URL=http://localhost:5000 # .env.production REACT_APP_API_URL=https://api.production.com
4.2 使用環(huán)境變量配置代理
// src/setupProxy.js
const { createProxyMiddleware } = require('http-proxy-middleware');
module.exports = function(app) {
app.use(
'/api',
createProxyMiddleware({
target: process.env.REACT_APP_API_URL,
changeOrigin: true
})
);
};5. 常見(jiàn)問(wèn)題和解決方案
5.1 跨域問(wèn)題
// src/setupProxy.js
module.exports = function(app) {
app.use(
'/api',
createProxyMiddleware({
target: 'http://localhost:5000',
changeOrigin: true,
onProxyRes: function(proxyRes, req, res) {
// 處理跨域響應(yīng)頭
proxyRes.headers['Access-Control-Allow-Origin'] = '*';
proxyRes.headers['Access-Control-Allow-Methods'] = 'GET,PUT,POST,DELETE,OPTIONS';
proxyRes.headers['Access-Control-Allow-Headers'] = 'Content-Type,Authorization';
}
})
);
};5.2 WebSocket 代理
// src/setupProxy.js
module.exports = function(app) {
app.use(
'/socket',
createProxyMiddleware({
target: 'ws://localhost:5000',
ws: true, // 啟用 websocket 代理
changeOrigin: true
})
);
};5.3 錯(cuò)誤處理
// src/setupProxy.js
module.exports = function(app) {
app.use(
'/api',
createProxyMiddleware({
target: 'http://localhost:5000',
changeOrigin: true,
onError: function(err, req, res) {
res.writeHead(500, {
'Content-Type': 'text/plain'
});
res.end('Proxy Error: ' + err);
}
})
);
};6. 生產(chǎn)環(huán)境配置
6.1 使用 nginx 配置
# nginx.conf
server {
listen 80;
server_name your-domain.com;
location /api {
proxy_pass http://backend-server;
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
}
location / {
root /usr/share/nginx/html;
index index.html;
try_files $uri $uri/ /index.html;
}
}7. 最佳實(shí)踐
開(kāi)發(fā)環(huán)境建議:
- 使用 setupProxy.js 進(jìn)行配置
- 避免在生產(chǎn)環(huán)境使用代理
- 使用環(huán)境變量管理配置
生產(chǎn)環(huán)境建議:
- 使用 nginx 等專(zhuān)業(yè)代理服務(wù)器
- 配置適當(dāng)?shù)木彺娌呗?/li>
- 注意安全性配置
調(diào)試技巧:
- 使用 console.log 調(diào)試代理配置
- 檢查網(wǎng)絡(luò)請(qǐng)求面板
- 驗(yàn)證請(qǐng)求頭和響應(yīng)頭
性能優(yōu)化:
- 合理使用緩存
- 避免不必要的代理
- 考慮使用負(fù)載均衡
到此這篇關(guān)于React 腳手架配置代理完整指南的文章就介紹到這了,更多相關(guān)React 腳手架配置代理內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
React18中請(qǐng)求數(shù)據(jù)的官方姿勢(shì)適用其他框架
這篇文章主要為大家介紹了官方回答在React18中請(qǐng)求數(shù)據(jù)的正確姿勢(shì)詳解,同樣也適用其他框架,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-07-07
react實(shí)現(xiàn)移動(dòng)端下拉菜單的示例代碼
這篇文章主要介紹了react實(shí)現(xiàn)移動(dòng)端下拉菜單的示例代碼,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-01-01
jenkins分環(huán)境部署vue/react項(xiàng)目的方法步驟
這篇文章主要介紹了jenkins分環(huán)境部署vue/react項(xiàng)目的方法,本文分步驟給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-02-02
react ant protable自定義實(shí)現(xiàn)搜索下拉框
這篇文章主要介紹了react ant protable自定義實(shí)現(xiàn)搜索下拉框,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-06-06
使用React-Window實(shí)現(xiàn)虛擬滾動(dòng)效果的示例代碼
React-Window?是一個(gè)為?React?應(yīng)用程序中高效渲染大數(shù)據(jù)集而設(shè)計(jì)的庫(kù),它基于窗口化或虛擬化的原則運(yùn)行,本文將使用React-Window實(shí)現(xiàn)虛擬滾動(dòng)效果,感興趣的可以了解下2024-01-01
react路由基礎(chǔ)解讀(Router、Link和Route)
這篇文章主要介紹了react路由基礎(chǔ)解讀(Router、Link和Route),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-07-07
ahooks封裝cookie?localStorage?sessionStorage方法
這篇文章主要為大家介紹了ahooks封裝cookie?localStorage?sessionStorage的方法示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-07-07

