访问通过Ajax Post发送到NodeJS服务器的数据

时间:2013-09-15 04:33:05

标签: jquery ajax node.js post

如何通过Ajax POST访问发送到Nodejs服务器的数据?

    //Client
$.ajax( {
    url: '/getExp',
    data: 'Idk Whats Rc',
    type: 'POST',
});

//Server
app.post('/getExp', function(req, res){
    var data = req.???; //I want data to be equal to 'Idk Whats Rc'
}

1 个答案:

答案 0 :(得分:8)

Express 4.x:

Express 4不再包含Connect作为依赖项,这意味着您需要单独安装正文解析模块。

解析器中间件可以在自己的GitHub存储库here中找到。它可以像这样安装:

npm install body-parser

对于表单数据,这就是中间件的使用方式:

var bodyParser = require('body-parser');
app.use(bodyParser.urlencoded());

对于Express 3.x及之前:

您需要使用Express中的bodyParser()中间件来解析HTTP请求的原始主体。然后中间件填充req.body

app.use(express.bodyParser());
app.post('/path', function(req, res) {
  console.log(req.body);
});

您可能希望将对象而不是字符串传递给POST请求,因为您目前拥有的内容将如下所示:

{ 'Idk Whats Rc': '' }

使用类似这样的代码:

$.ajax({
  url: '/getExp',
  data: { str: 'Idk Whats Rc' },
  type: 'POST',
});

会告诉你的:

{ str: 'Idk Whats Rc' }