Express.js POST req.body empty

佐手、 提交于 2019-11-27 07:44:08

问题


So I have the following code in my server.js file that I'm running with node.js. I'm using express to handle HTTP requests.

app.post('/api/destinations', function (req, res) {
  var new_destination = req.body;
  console.log(req.body);
  console.log(req.headers);
  db.Destination.create(new_destination, function(err, destination){
    if (err){
      res.send("Error: "+err);
    }
    res.json(destination);
  });
});

I'm running the following in Terminal:

curl -XPOST -H "Content-Type: application/json" -d '{"location": "New York","haveBeen": true,"rating": 4}' http://localhost:3000/api/destinations

After running that server.js prints out the following.

{}
{ host: 'localhost:3000',
  'user-agent': 'curl/7.43.0',
  accept: '*/*',
  'content-type': 'application/json',
  'content-length': '53' }

So req.body is {}. I read other Stack Overflow posts about similar issues where content-type was not correct because of body-parser. But that isn't the issue because content-type is application/json.

Any ideas how to get the actual body of the request?

Thanks in advance.


回答1:


You need bodyParser.json as well:

app.use(bodyParser.urlencoded({ extended: true }));
app.use(bodyParser.json());



回答2:


Sometimes the req.body shows {} if you forgot to put the name attribute to the form input fields. Following is an example:

<input type="email" name="myemail" class="form-control" id="exampleInputEmail2" placeholder="Email address" required>

Then the req.body shows { myemail: 'mathewjohnxxxx@gmail.com' }

I post this answer because, i have encountered the similar problem and this worked for me.




回答3:


Make sure if you are making the form and inputs in javascript that you append the input to the form. That was my issue.

yourForm.appendChild(yourInput);


来源:https://stackoverflow.com/questions/38294730/express-js-post-req-body-empty

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!