React ts模式使用http-proxy-middleware代理时访问报404问题
React ts模式使用http-proxy-middleware代理时访问报404
create-react-app脚手架创建Recat应用,选择的是TypeScript
根据http-proxy-middleware文档 在src目录创建setupProxy.js,一直报错
const { createProxyMiddleware } = require('http-proxy-middleware');
module.exports = function(app) {
app.use(
createProxyMiddleware('/custom', {
target: 'http://127.0.0.1:7001',
changeOrigin: true, // needed for virtual hosted sites
ws: true, // proxy websockets
pathRewrite: {
'^/custom': ''
}
})
)
};解决方式
将setupProxy.js复制一份后缀改成ts可正常访问(setupProxy.ts setupProxy.js)
http-proxy-middleware的坑
react项目启动,页面显示“无法访问网站”,原因之一是代理脚本(setupProxy.js)的语法与版本对应不上。

解决方法:
旧版本写法
在src下新建setupProxy.js;
const proxy = require("http-proxy-middleware")
module.exprots = function (app) {
app.use(
proxy('/api1', {
target: 'http://localhost:5000',
changeOrigin: true, // 控制服务器收到的请求头host字段的值
pathRewrite: { '^/api1': '' } // 路径重写
})
)
}
新版本写法
在src下新建setupProxy.js;
const { createProxyMiddleware } = require('http-proxy-middleware')
module.exports = function (app) {
app.use('/api', createProxyMiddleware({
target: 'http://localhost:3000',
changeOrigin: true,
pathRewrite: {
"^/api": "/api"
}
}))
}
注意!!!!!!
两种写法的前缀位置是不一样的,旧版本是作为proxy的参数,新版本是app.use的参数
总结
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。
相关文章
D3.js(v3)+react 实现带坐标与比例尺的散点图 (V3版本)
散点图(Scatter Chart),通常是一横一竖两个坐标轴,数据是一组二维坐标,分别对应两个坐标轴,与坐标轴对应的地方打上点。由此可以猜到,需要的元素包括circle(圆)和axis(坐标轴),接下来通过本文大家分享D3.js(v3)+react 实现带坐标与比例尺的散点图 (V3版本) ,一起看看2019-05-05
Remix 后台桌面开发electron-remix-antd-admin
这篇文章主要为大家介绍了Remix 后台桌面开发electron-remix-antd-admin的过程示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪2023-04-04


最新评论