React create-react-app 里配置代理(解决跨域)

配置代理:

creact-react-app v5

当然不是v5 下面的方法也适用。

方式一:package.json里配置

其实 cra里给了个简单的配置代理 就是在package.json里加上proxy就行了。

修改时需要 npm start重新运行一下,要不然可能不生效。

proxy只能以 http:// 或https://开头 否则会报:
When "proxy" is specified in package.json it must start with either http:// or https://:

示例:

比如后端给的完整地址如下:

http://10.16.xx.xxx:8080/fund_diag/fund_home/select_by_fund

这一段是相同的地址(也就是所有接口都是这个前缀),根据你的接口来定。

javascript 复制代码
"proxy": "http://10.16.xx.xx:8080/fund_diag"

然后使用即可 比如 axios url直接请求就行代码如下:

request就是axios 只是我又封装了一层。

javascript 复制代码
   // axios.get(url, { params })
    request.get("/fund_home/select_by_fund?fund=1001").then(res=>{
      console.log(res);
    })

然后启动项目就可以看到请求成功了(不配置proxy是成功不了的,因为跨域了)。

network截图:

方式二:http-proxy-middleware 配置代理

1.安装 http-proxy-middleware

powershell 复制代码
npm install --save http-proxy-middleware

2.在src下新建 setupProxy.js 文件名必须是这个 然后配置一下即可。

javascript 复制代码
const { createProxyMiddleware } = require('http-proxy-middleware');
module.exports = function(app) {
    app.use(
      '/api',
      createProxyMiddleware({
        target: 'http://10.16.xx.xxx:8080/fund_diag', //代理的地址
        changeOrigin: true,
        pathRewrite: {
          '^/api': ''  // 将请求路径中的 "/api" 替换为 ""
        }
      })
    )
  };

axios使用/api/xx 即可走代理:

javascript 复制代码
    // axios.get(url, { params })
    request.get("/api/fund_home/select_by_fund?fund=1001").then(res=>{
      console.log(res);
    })

示例:

比如后端给的完整地址如下:

http://10.16.xx.xxx:8080/fund_diag/fund_home/select_by_fund

http://10.16.xx.xxx:8080/fund_diag这段是接口的前缀,也就是每个接口都有这段。所以 我target 配置为 :http://10.16.xx.xxx:8080/fund_diag

当然 具体需需要怎么配置,根据你的接口来定

network截图:

相关推荐
鹏北海-RemHusband几秒前
踩坑记录:iOS Safari 软键盘下的“幽灵弹窗“问题
前端·ios·safari
一位搞嵌入式的 genius4 分钟前
深入理解浏览器中的 JavaScript:BOM、DOM、网络与性能优化
前端·javascript·网络·性能优化
lang201509284 分钟前
一键生成Java Web项目:Tomcat-Maven原型解析
java·前端·tomcat
We་ct6 分钟前
LeetCode 242. 有效的字母异位词:解法解析与时空优化全攻略
前端·算法·leetcode·typescript
David凉宸10 分钟前
Vue 3生态系统深度解析与最佳实践
前端·javascript·vue.js
全栈小518 分钟前
【前端】win11操作系统安装完最新版本的NodeJs运行npm install报错,提示在此系统上禁止运行脚本
前端·npm·node.js
晚霞的不甘21 分钟前
Flutter for OpenHarmony3D DNA 螺旋可视化:用 Canvas 构建沉浸式分子模型
前端·数据库·经验分享·flutter·3d·前端框架
摘星编程1 小时前
React Native + OpenHarmony:Stepper步进器组件
javascript·react native·react.js
●VON1 小时前
React Native for OpenHarmony:简易计算器应用的开发与跨平台适配实践
javascript·react native·react.js
摘星编程8 小时前
OpenHarmony + RN:Placeholder文本占位
javascript·react native·react.js