Я пишу программу, которая использует React в качестве внешнего интерфейса и API Express / Node для внутреннего интерфейса, который затем выполняет операции CRUD в базе данных MongoDB.Прямо сейчас я использую встроенный API JS fetch () для выполнения операций GET / POST на моем внешнем интерфейсе.GET-запросы работают нормально, но мои POST-запросы, похоже, не работают.На моем внешнем интерфейсе у меня есть форма и обработчик для отправки формы следующим образом:
handleSubmit(){
let databody = {
"name": this.state.nameIn,
"quote": this.state.quoteIn
}
return fetch('http://localhost:5002/stored', {
method: 'POST',
body: JSON.stringify(databody),
headers: {
'Content-Type': 'application/json'
},
})
.then(res => res.json())
.then(data => console.log(data));
}
render(){
return (
<div>
<form onSubmit={this.handleSubmit}>
<label>
Name
<input type="text" name="name" value={this.nameIn} onChange={this.handleNameChange}/>
</label>
<label>
quote
<input type="text" name="quote" value={this.quoteIn} onChange={this.handleQuoteChange}/>
</label>
<input type="submit" value="Add to DB" />
</form>
</div>
);
}
Затем в моем Express API, который находится на порту 5002, у меня есть:
app.post('/stored', (req, res) => {
console.log(req.body);
db.collection('quotes').insertOne(req.body, (err, data) => {
if(err) return console.log(err);
res.send(('saved to db: ' + data));
})
});
Однако при отправке формы запрос отображается в Express API с пустым телом.Console.log показывает, что req.body - это просто {} Мне интересно, что я сделал не так?