一个简单的代理方式

  1. 可以在package.json文件中加入** “proxy”:“http://www.kuwo.cn(这个是请求地址)”**加完必须重启一下项目
  2. 可以创建一个setupProxy.js文件 必须是此命名
    代码结构如下
const proxy = require('http-proxy-middleware')

module.exports = function (app){
    app.use(
        proxy('/api1',{
            target:'http://www.kuwo.cn',
            changeDrigin:true,
            pathRewrite:{'^/api1':''}
        })
    )
}

加完之后在添加地址时必须加上一个自定义的这个
在这里插入图片描述
就好像这样
在这里插入图片描述

同样的 加完后也得重启项目
就可以获取到数据啦

在这里插入图片描述

react脚手架配置代理总结

方法一

在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. 缺点:配置繁琐,前端请求资源时必须加前缀。
    ``

这里代码请求的是酷我音乐 代码如下:
App.js

import React, { Component } from 'react'
import axios from 'axios';
export default class App extends Component {
state={
  aidio:''
}
  componentDidMount(){
    axios.get('http://localhost:3000/api1/url?format=mp3&rid=7201082&response=url&type=convert_url3&br=128kmp3&from=web&t=1628651363998&httpsStatus=1&reqId=87a53be1-fa51-11eb-8307-03c2b3d0bbeb').then(
      response=>{
        console.log('成功',response);
        this.setState({
          aidio:response.data.url
        })
      },
      error=>{console.log('失败了',error);}
    )
  }

  getStudentData=()=>{
    console.log(this.state.aidio);
  }
  render() {
    return (
      <div>
  <audio controls src={this.state.aidio}></audio>

        <button onClick={this.getStudentData}> 点我获取学生数据 </button>
      </div>
    )
  }
}

setupProxy.js

const proxy = require('http-proxy-middleware')

module.exports = function(app){
	app.use(
		proxy('/api1',{ //遇见/api1前缀的请求,就会触发该代理配置
			target:'http://www.kuwo.cn', //请求转发给谁
			changeOrigin:true,//控制服务器收到的请求头中Host的值
			pathRewrite:{'^/api1':''} //重写请求路径(必须)
		}),
		proxy('/api2',{
			target:'http://localhost:5001',
			changeOrigin:true,
			pathRewrite:{'^/api2':''}
		}),
	)
}


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

爱吃囍囍丸子

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值