内联JavaScript和Node.js之间的通信



我正在使用Node.js,我想发送一个请求,其中包含一个输入值到服务器时,按下一个按钮。

这是我的HTML代码:
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<script src="https://code.jquery.com/jquery-3.6.0.min.js"></script>
</head>
<body>
<input id="input" action="/onclick" autocomplete="off">
<button id="button">Send</button>
<script>
let input = document.getElementById('input');
document.getElementById('button').addEventListener('click', (event) => {
event.preventDefault();
let value = input.value;
if (value) {
let data = {};
data.title = 'getValue',
data.message = value;
$.ajax({
url:'/onclick',
data: JSON.stringify(data),
type: 'POST',
success: (responseData) => {
console.log('Success!');
},
});
input.value = null;
}
});
</script>
</body>
</html>

这是我的server.js:

const express = require('express');
const app = express();
const http = require('http');
const server = http.createServer(app);
app.get('/', (req, res) => {
res.sendFile(__dirname + '/index.html');
});
app.post('/onclick', (req, res) => {
console.log('body: '+ JSON.stringify(req.message));
res.send(req.message);
});
server.listen(3000, () => {
console.log('listening on *:3000');
});

代码没有抛出任何错误(它返回Success!在浏览器控制台),但问题是,在Node.js shell它发送body: undefined而不是输入值。

你知道怎么解决这个问题吗?

提前感谢,

在server.js中添加这一行来访问请求正文:

app.use(express.json());

req.body代替req.message访问请求体

最新更新