分別是這四種:
www-form-urlencoded,
form-data,
application/json,
text/xml
- www-form-urlencoded
這是http的post請求默認的數據格式,需要body-parser中間件的支持
服務器端的demo:
var express = require('express'); var app = express(); var bodyParser = require('body-parser'); app.use(bodyParser.urlencoded({ extended:true })); app.post('/urlencoded', function(req, res){ console.log(req.body); res.send(" post successfully!"); }); app.listen(3000);
可以用postman進行測試,這里就不贅述。
- form-data
這種方式一般用於數據上傳,需要中間件connect-multiparty的支持
服務器端的demo: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
body-parser中間件支持json解析, 添加中間件進行解析即可app.use(bodyParser.json());
text/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)); }); }); app.listen(3000);