npm body-parser 中文api

body-parser

node.js body parsing 中间件

安装


$ npm install body-parser

API


var bodyPaeser =require('body-parser')
可以通过body-parser 对象创建中间件,当接收到客户端请求时所有的中间件都会给req.body 添加属性,请求体为空,则解析为空{} (或者出现错误)。

bodyParser.json(options)

中间件只会解析 json ,允许请求提任意Unicode编码支持 gzipdeflate 编码。

options

一个对象,有以下属性
inflate
默认为false,true->压缩的请求体会被解压,false->压缩的请求提不被解压。
limit
控制请求体最大大小,默认为100kb,当为数字时会转换为bytes,当为字符串时,value值会通过 bytes库 转换为字节大小。
reviver
此选项会通过JSON.parse直接传给其第二个参数。
strict
默认为true,当为true时只接受数组和对象,当为false时会接受任何JSON.parse 能接受的。
type
type 选项用来决定中间件要解析媒体类型。选项可以是一个函数或者是字符串。当为字符串时,可以直接通过type-is 库直接传递给选项,字符串也可以为一个扩展名(例如json)、mime 类型(application/json、/ 、*/json)。当为函数时:默认为application/json。
verify
verify选项,若缺失则为一个函数function(req,res,buf,encoding),buf为一个Buffer。

bodyParse.raw(option)

将请求体内容作为Buffer来处理,并返回。支持gzip deflate 压缩。
inflate
limit
type
verify

bodyParser.text(option)

将请求提内容作为字符串来处理,并返回。支持gzip deflate 压缩。
defaultCharset
若请求头未设置Content-Type则默认为utf8
inflate
type
verify

bodyParser.urlencoded(option)

中间件只解析urlencoded 请求体,并返回,只支持UTF-8编号文本,支持gzip deflate 压缩。
extend
ture->使用queryString库(默认) false->使用qs库。
limit
parameterlimit
指定parameters最长长度,默认1000
type
verify
body-parser 是一个 Node.js 中间件,用于处理 HTTP 请求体中的数据。它可以解析 JSON、Raw、文本、URL-encoded 格式的请求体,并且提供了多种选项来控制解析方式。 安装: 使用 npm 安装: ``` npm install body-parser ``` 使用: 在 Express 应用中使用 body-parser: ```javascript const express = require('express') const bodyParser = require('body-parser') const app = express() // 解析 application/json app.use(bodyParser.json()) // 解析 application/x-www-form-urlencoded app.use(bodyParser.urlencoded({ extended: false })) // 解析 text/plain app.use(bodyParser.text()) // 解析 raw app.use(bodyParser.raw()) // 处理业务逻辑 app.post('/api', (req, res) => { console.log(req.body) res.send('success') }) app.listen(3000, () => { console.log('Server started on port 3000') }) ``` 在上面的示例中,我们通过 `app.use` 方法来注册 body-parser 中间件。然后,我们可以使用 `req.body` 来访问请求体中的数据。 body-parser 支持多种解析方式,通过传递不同的参数来控制解析方式。例如,`bodyParser.urlencoded({ extended: false })` 可以控制解析 URL-encoded 格式的请求体时,是否使用 `querystring` 库来解析数据。如果将 `extended` 参数设置为 `true`,则使用 `qs` 库来解析数据。 除了上述示例中的常见解析方式,body-parser 还支持自定义解析函数,可通过 `bodyParser.raw(options)` 或 `bodyParser.text(options)` 方法来注册。 更多详细信息,请参阅官方文档:https://github.com/expressjs/body-parser#readme
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值