bodyParser中间件用来解析http请求体,是express默认使用的中间件之一。
1.这个模块提供以下解析器
(1) JSON body parser (2) Raw body parser (3)Text body parser (4)URL-encoded form body parser
2.如何安装
npm install body-parser
3.API
var bodyParser = require('body-parser');
可以通过body-parser对象创建中间件,当接受到客户端请求时所有的中间件都会给req.body添加属性,请求内容为空时,解析为空或者错误。
(1)bodyParser.json(options)
处理json数据
app.use(bodyParser.json());
(2)bodyParser.raw(options)
处理Buffer数据流
(3)bodyParser.text(options)
处理文本数据
(4)bodyParser.urlencoded(options)
处理UTF-8的编码的数据
app.use(bodyParser.urlencoded({extented:false}))
extend
ture->使用queryString库(默认) false->使用qs库。
使用express应用生成器生成一个网站,它默认已经使用了 bodyParser.json
与 bodyParser.urlencoded
的解析功能,除了这两个,bodyParser还支持对text、raw的解析。
顾名思义,bodyParser.json是用来解析json数据格式的。bodyParser.urlencoded则是用来解析我们通常的form表单提交的数据,也就是请求头中包含这样的信息: Content-Type: application/x-www-form-urlencoded
bodyParser.urlencoded
模块用于解析req.body的数据,解析成功后覆盖原来的req.body,如果解析失败则为 {}
。
常见的四种Content-Type类型:
application/x-www-form-urlencoded
常见的form提交
var bodyParser = require('body-parser'); app.use(bodyParser.urlencoded({ extended: false })); app.post('/api/user/insert', function (req, res) { console.log(req.body); })
multipart/form-data
文件提交
var multipart = require('connect-multiparty'); var multipartMiddleware = multipart(); app.post('/formdata',multipartMiddleware, function (req, res) { console.log(req.body); res.send("post successfully!"); });
application/json
提交json格式的数据
var bodyParser = require('body-parser'); app.use(bodyParser.json()); app.post('/api/user/insert', function (req, res) { console.log(req.body); })
text/xml
提交xml格式的数据
body-parser默认不支持这种数据格式
- 解决方法:把请求体参数按照字符串读取出来,然后使用 xml2json 包把字符串解析成json对象,然后对json对象进行操作,方便得多。
- 注意:我们还是要使用 body-parse 得到字符串,然后再转化.
利用req上定义的事件 data 来获取http请求流, end 事件结束请求流的处理.
利用 xml2json 把上面得到的请求参数流(我们直接转化为字符串)转化为 json 对象.
demo如下:
var express = require('express'); var bodyParser = require('body-parser'); var xml2json=require('xml2json'); var app = express(); app.use(bodyParser.urlencoded({ extended: true })); app.post('/xml', function (req, res) { req.rawBody = '';//添加接收变量 var json={}; req.setEncoding('utf8'); req.on('data', function(chunk) { req.rawBody += chunk; }); req.on('end', function() { json=xml2json.toJson(req.rawBody); res.send(JSON.stringify(json)); }); });
更改之后就可以收到axiso传来的数据了,将来如果正式环境用到可以统一协商一下,使用application/x-www-form-urlencoded还是json,然后前后端统一更改就可以了。