body-parser 中间件的作用
解析 HTTP 请求体数据的 Node.js 中间件
问题
body-parser 这个中间件是做什么用的?
解答
body-parser 是一个 Node.js 中间件,用于解析 HTTP 请求中的请求体(Request Body),并将其转换为 JavaScript 对象。它可以帮助开发者方便地从 POST、PUT、DELETE 等请求中获取请求体数据。
支持的数据格式
body-parser 支持以下几种请求体数据格式:
JSON 格式:通过 json() 方法解析 JSON 格式的请求体数据,并将其转换为 JavaScript 对象。
URL 编码格式:通过 urlencoded() 方法解析 URL 编码格式的请求体数据,并将其转换为 JavaScript 对象。
多部分数据格式:通过 multipart() 方法解析多部分数据格式的请求体数据,并将其转换为 JavaScript 对象。
使用示例
const express = require('express');
const bodyParser = require('body-parser');
const app = express();
// 解析 URL 编码格式的请求体
app.use(bodyParser.urlencoded({ extended: false }));
// 解析 JSON 格式的请求体
app.use(bodyParser.json());
app.post('/login', (req, res) => {
// 通过 req.body 获取请求体数据
const { username, password } = req.body;
console.log('用户名:', username);
console.log('密码:', password);
res.send('登录成功');
});
app.listen(3000, () => {
console.log('服务器运行在 3000 端口');
});
关键点
- body-parser 将请求体数据解析为 JavaScript 对象,通过
req.body访问 - 需要根据实际数据格式选择合适的解析方法(
json()、urlencoded()等) - 使用时要注意配置参数,防止安全漏洞(如限制请求体大小)
- 必须对请求体数据进行有效性验证和安全性检查
- Express 4.16+ 已内置 body-parser 功能,可直接使用
express.json()和express.urlencoded()
目录