ReactJS 和 Express 与 Axios 返回 404

IT技术 reactjs forms react-native react-redux axios
2021-05-26 12:53:02

不确定我的代码发生了什么,但我正在尝试使用 axios 控制台进行测试运行并记录一些内容,但我收到了 404。

class SubscribeForm extends Component {
  constructor(props) {
    super(props);
    this.state = {value: ''};

    this.emailChange = this.emailChange.bind(this);
    this.emailSubmit = this.emailSubmit.bind(this);
  }

  emailChange(e) {
    this.setState({value: e.target.value});
  }

  emailSubmit(e) {
    e.preventDefault();
    axios.post('/subscribe', {
      email: 'someemail@email.com',
      headers: {
        'Content-Type': 'application/json;charset=UTF-8',
        "Access-Control-Allow-Origin": "*",
      }
    }).then(res => {
      if(res.data.success) {
        this.setState({email: ''})
      }
    }).catch(error => {
      if (error.response) {
        // The request was made and the server responded with a status code
        // that falls out of the range of 2xx
        console.log(error.response.data);
        console.log(error.response.status);
        console.log(error.response.headers);
      } else if (error.request) {
        // The request was made but no response was received
        // `error.request` is an instance of XMLHttpRequest in the browser and an instance of
        // http.ClientRequest in node.js
        console.log(error.request);
      } else {
        // Something happened in setting up the request that triggered an Error
        console.log('Error', error.message);
      }
      console.log(error.config);
    });
  }

  render() {
    const { classes } = this.props;
    return (
      <div className={classes.subFormSection}>
        <p className={classes.formHelper}>
          Join the club, enter your email address
        </p>

        <form method="post" className={classes.subFormWrap} onSubmit={this.emailSubmit}>
          <TextField
            value = {this.state.value}
            onChange = {this.emailChange}
          />
          <Button
            className={classes.button}
            type="submit"
          >
            Send
            <Icon className={classes.rightIcon}>send</Icon>
          </Button>
        </form>
      </div>
    );
  }
}

我尝试将标头添加到 axios 中以查看这是否是问题所在,但我认为不是(或者我可能做错了)。

另外,我没有 /subscribe 文件,我认为我不需要吗?因为,我在这里用 express 捕捉它:

const cors = require("cors");

app.use(cors());

app.post("/subscribe", (req, res, next) => {
  console.log(req.body.email);
});

这个文件在我的服务器文件中,而react部分在客户端文件中。我设置了代理,所以当我运行服务器时,前端和后端正在相互交谈。


已更新 404 状态已转(待定)

我还在我的客户端文件夹中设置了代理中间件 setupProxy.js

const proxy = require("http-proxy-middleware");

module.exports = function(app) {
  app.use(proxy("/subscribe", {
    target: "http://localhost:5000"
  }));
};

我在我的网络请求中进入请求标头/subscrib

Provisional headers are shown

这是否导致它(待定)?

2个回答

据我所知,您的服务器和客户端应用程序似乎在不同的端口上运行。如果是这种情况,您不能这样做:

axios.post('/subscribe', {
      email: 'someemail@email.com',
      headers: {
        'Content-Type': 'application/json;charset=UTF-8',
        "Access-Control-Allow-Origin": "*",
      }
})

您正在使用/subscribe没有主机的路径Axios 尝试使用运行您的客户端应用程序的主机,但它找不到该路径,因此无法找到404状态代码。

如果是这种情况,您可以在/subscribe路径之前使用服务器的主机和端口来修复它见下文:

axios.post('localhost:4000/subscribe', {
      email: 'someemail@email.com',
      headers: {
        'Content-Type': 'application/json;charset=UTF-8',
        "Access-Control-Allow-Origin": "*",
      }
})

请将此处的端口更改localhost:4000为您的服务器端口。

注意:这仅适用于您的本地开发。

如果您计划部署该应用程序,则可能需要process.env.PORT改用。

您可以使用浏览器的检查元素来检查请求是否正确(检查元素 > 网络)。

通过查看代码,我认为您缺少基本网址。

它应该像

axios.post(baseul + port + request url)

例子:

axios.post('http://localhost:3000/subscribe')