AJAX错误:400错误请求

时间:2017-01-18 22:21:41

标签: javascript ajax node.js express mithril.js

我正在使用mithril.js连接我的节点后端。我正在关注AJAX请求中的文档添加,并且在其他地方的mithril文档很少。

无论如何,错误:

mithril.js:2130 POST http://localhost:3000/api/stocks 400 (Bad Request)
ta @ mithril.js:2130
ua @ mithril.js:2138
k.request @ mithril.js:2227
vm.add @ app.js:24
(anonymous) @ mithril.js:1246
mithril.js:2197 Uncaught SyntaxError: Unexpected token < in JSON at position 0
    at parse (<anonymous>)
    at Object.a.onload.a.onerror (mithril.js:2197)
    at XMLHttpRequest.d.onreadystatechange (mithril.js:2102)
a.onload.a.onerror @ mithril.js:2197
d.onreadystatechange @ mithril.js:2102

mithril.js

vm.add = function() {
            var data = vm.symbol();
            if (vm.symbol()) {
                m.request({method: 'POST',
                            url: '/api/stocks',
                            data: data,
                            unwrapSuccess: function(response) {
                              return response.data;
                            },
                            unwrapError: function(response) {
                              return console.log(response.error);
                              }
                            });
                vm.list.push(new app.Stock({symbol: vm.symbol()}));
                vm.symbol("");
            }
        };

routes / index.js(node)

router.post('/api/stocks', function(req, res) {
  Stocks.create({
    stock: req.body.text, //stocks
    date_added: new Date(), //Date
  }, function (err, stocks) {
    if (err) {
      res.send(err);
    } else {
      Stocks.find(function(err, stocks) {
        if (err) {
          res.send(err);
        } else {
          res.json(stocks);
        }
      });
    };
  });
});

有什么想法吗?

谢谢。

1 个答案:

答案 0 :(得分:1)

问题是由于Mithril自动假设数据为JSON而引起的。我试图发送纯文本。秘银有一种称为“反序列化”的方法。

反序列化不起作用所以我再看一遍并且表达不喜欢没有JSON的事实所以我将数据转换为JSON然后POST请求工作正常。