首页 > 解决方案 > 如何使用 XMLHttpRequest 将数据从客户端 Javascript 传递到 node.js?

问题描述

我的index.html文件中有 HTML 输入。

<input type="text" id="handle" >
<input type="text" id="message" >
<button id="send">send</button>

当我填写数据并单击发送时,我想将它们发送到我的节点脚本,在那里我可以对传递的数据做一些事情。

我的index.html的脚本:

$("#send").on("click", function() {
    var message = $("#message").val();
    var handle = $("#handle").val();


    var xhr = new XMLHttpRequest();
    var data = {
        param1: handle,
        param2: message
    };
    xhr.open('POST', '/data');
    xhr.onload = function(data) {
        console.log('loaded', this.responseText);
    };
    xhr.setRequestHeader('Content-Type', 'application/json');
    xhr.send(JSON.stringify(data));

});

以及我如何尝试在我的服务器端test.js文件中接收数据。

app.post('/data', function(req, res){

    var obj = {};
    console.log('body: ' + req.body);
    res.send(req.body);

});

在这种情况下,输出显示: body: undefined

如何将数据从客户端页面发送到服务器端,以便我可以使用它们执行其他操作?

标签: javascriptnode.jsexpressxmlhttprequest

解决方案


您只需要在 Express 中使用 JSON 正文解析器,如下所示:

const express = require('express');
const bodyParser = require('body-parser');
const app = express();
const port = 3000;

app.use(express.static('./'));
/* Parse JSON data using body parser. */
app.use(bodyParser.json());

app.post('/data', function(req, res){
    console.log('body: ',  req.body);
    res.send(req.body);
});

app.listen(port);

如果此模块不存在,只需为此模块执行 npm 安装:

npm install body-parser

推荐阅读