Я использую http-proxy-middleware для отправки данных формы с внешнего интерфейса React на Express сервер,
, но http-proxy-middleware
, похоже, не работает.
Он должен работать с localhost://5000
.
Вместо этого выдает ошибку:
POST http://localhost: 3000 / API / SendMail 404 (не найдено).
front код завершения:
import React, { Component } from "react";
import axios from "axios";
class EmailForm extends Component {
state = {
name: "",
email: ""
};
handleSubmit = async e => {
e.preventDefault();
const data = {
name: this.state.name,
email: this.state.email
};
console.log(data);
axios.post("/api/sendMail", data);
};
handleChange = e => {
this.setState({
[e.target.id]: e.target.value
});
};
render() {
return (
<div className="container mt-3">
<form onSubmit={this.handleSubmit}>
<h4 className="grey-text text-darken-3">Send Email</h4>
<div className="form-group">
<label htmlFor="email">Name</label>
<input
className="form-control"
type="text"
id="name"
onChange={this.handleChange}
/>
</div>
<div className="form-group">
<label htmlFor="email">Email</label>
<input
className="form-control"
type="email"
id="email"
onChange={this.handleChange}
/>
</div>
<div className="form-group">
<button className="btn btn-danger">SendMeEmail</button>
</div>
</form>
</div>
);
}
}
export default EmailForm;
setupProxy. js:
const proxy = require("http-proxy-middleware");
module.exports = function(app) {
app.use(proxy("/api", { target: "http://localhost:5000/" }));
};
Сервер. js:
app.post("/api/sendMail", (req, res) => {
console.log(req.body);
});