16. React配置代理proxy

文章目录

  • 可以直接看 3. 总结
  • 1.react如何解决跨域问题
    • 1.1 跨域是什么
    • 1.2 react请求跨域是什么
  • 2. react如何解决跨域
    • 方式1 通过配置代理 proxy
      • 原理
      • 操作步骤
      • 注意
    • 方式2 使用配置文件
  • 3. 总结
    • 方法一
    • 方法二

可以直接看 3. 总结

1.react如何解决跨域问题

1.1 跨域是什么

  • SpringBoot2.x跨域问题
  • 1.2 react请求跨域是什么

16. React配置代理proxy_第1张图片

2. react如何解决跨域

方式1 通过配置代理 proxy

原理

  • ajax请求可以发送到服务器,但是浏览器无法接受服务器返回结果,因为跨域
  • 解决方法1 如下使用代理服务器作请求转发再返回
    16. React配置代理proxy_第2张图片

操作步骤

  • 找到并打开 package.json
  • 添加配置
  • 假如 server地址 http://localhost:5000
  • react client地址 localhost:3000
//"proxy":"服务器地址+端口号"
"proxy":"http://localhost:5000"
  • 在axios请求中发送请求

axios.get("http://localhost:3000/wx_search/search_data_class_all/").then(
  response => {console.log("success",response.data)},
  error => {console.log("failed",error);}
)

结果如下:
在这里插入图片描述

注意

  • 是否所有的代理请求都会发送到服务器?
    • 不是,因为public文件夹相当于项目根路径,如果请求 public/index.html则不会向服务器发送请求。例如:http://localhost:3000/index.html
    • 返回结果如下
      16. React配置代理proxy_第3张图片
    • 返回的是 public/index.html的代码
    • 所以一个请求的执行是先从本地对应端口的根路径下面找,找不到再向服务器发送转发请求

方式2 使用配置文件

  • 配置文件位置 src/
  • 配置文件名称固定,webpack会自动寻找加载 setupProxy.js
  • 配置文件使用的是 cjs common js 因为是webpack使用的nodejs的语法
// cjs语法  引入代理中间件
const proxy = require("http-proxy-middleware")

module.exports = function(app){
    app.use(
        proxy(
            "/api01",
            {
                target:"http://localhost:5000",  //遇见 /api01前缀的请求,会触发该代理
                changeOrigin:true,  //控制服务器接收的host地址是真实地址false,还是代理地址true
                pathRewrite:{"^/api01":""} //去掉请求路径里用于区分的前缀
            }
        )
        //可以配置多个代理,使用 英文逗号隔开
    )
}


3. 总结

方法一

在package.json中追加如下配置

"proxy":"http://localhost:5000"

说明:

  1. 优点:配置简单,前端请求资源时可以不加任何前缀。
  2. 缺点:不能配置多个代理。
  3. 工作方式:上述方式配置代理,当请求了3000不存在的资源时,那么该请求会转发给5000 (优先匹配前端资源)

方法二

  1. 第一步:创建代理配置文件

    在src下创建配置文件:src/setupProxy.js
    
  2. 编写setupProxy.js配置具体代理规则:

    const proxy = require('http-proxy-middleware')
    
    module.exports = function(app) {
      app.use(
        proxy('/api1', {  //api1是需要转发的请求(所有带有/api1前缀的请求都会转发给5000)
          target: 'http://localhost:5000', //配置转发目标地址(能返回数据的服务器地址)
          changeOrigin: true, //控制服务器接收到的请求头中host字段的值
          /*
          	changeOrigin设置为true时,服务器收到的请求头中的host为:localhost:5000
          	changeOrigin设置为false时,服务器收到的请求头中的host为:localhost:3000
          	changeOrigin默认值为false,但我们一般将changeOrigin值设为true
          */
          pathRewrite: {'^/api1': ''} //去除请求前缀,保证交给后台服务器的是正常请求地址(必须配置)
        }),
        proxy('/api2', { 
          target: 'http://localhost:5001',
          changeOrigin: true,
          pathRewrite: {'^/api2': ''}
        })
      )
    }
    

说明:

  1. 优点:可以配置多个代理,可以灵活的控制请求是否走代理。
  2. 缺点:配置繁琐,前端请求资源时必须加前缀。

你可能感兴趣的:(React,react)