For some reason when I make an ajax post using jQuery, the body, as received by node is empty. Here is my ajax post:
jQuery
var formData = {
    'order': order,
    'words': 'words'
};
$.ajax({
    type: 'post',
    url: 'https://example.com/charge',    
    processData: false,
    data: JSON.stringify(formData),
    contentType: 'json', 
    xhrFields: {
        withCredentials: false
    },  
    headers: {
    }, 
    success: function (data) {
        console.log('Success');
        console.log(data);
    },  
    error: function () {
        console.log('We are sorry but our servers are having an issue right now');
    }
})
And here is my node code:
Node
app.js
app.use(bodyParser.json());
app.use(bodyParser.urlencoded({ extended: false }));
app.use('/', routes);
routes/index.js
router.post('/charge', function(req, res) {
    console.log(req.body);
} //This always logs {}
I have no idea what  I could be doing wrong here. My browser even shows a payload and the post request (the formData object) but node logs nothing.  Any ideas?
Use ajax request like this:
$.ajax({
    type: 'post',
    url: 'https://example.com/charge',   
    data: formData,
    xhrFields: {
        withCredentials: false
    },  
    headers: {
    }, 
    success: function (data) {
        console.log('Success');
        console.log(data);
    },  
    error: function () {
        console.log('We are sorry but our servers are having an issue right now');
    }
})
Mine was not working too, but solved by using,
contentType: 'application/json',
data: JSON.stringify(formdata),
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With