node.js中怎么利用express解析post請求,相信很多沒有經(jīng)驗的人對此束手無策,為此本文總結(jié)了問題出現(xiàn)的原因和解決方法,通過這篇文章希望你能解決這個問題。
專注于為中小企業(yè)提供網(wǎng)站建設(shè)、網(wǎng)站設(shè)計服務(wù),電腦端+手機端+微信端的三站合一,更高效的管理,為中小企業(yè)臨潼免費做網(wǎng)站提供優(yōu)質(zhì)的服務(wù)。我們立足成都,凝聚了一批互聯(lián)網(wǎng)行業(yè)人才,有力地推動了上1000家企業(yè)的穩(wěn)健成長,幫助中小企業(yè)通過網(wǎng)站建設(shè)實現(xiàn)規(guī)模擴(kuò)充和轉(zhuǎn)變。
1、www-form-urlencoded
這是http的post請求默認(rèn)的數(shù)據(jù)格式,需要body-parser中間件的支持
服務(wù)器端的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進(jìn)行測試,這里就不贅述。
2、form-data
這種方式一般用于數(shù)據(jù)上傳,需要中間件connect-multiparty的支持
服務(wù)器端的demo:
var multipart = require('connect-multiparty'); var multipartMiddleware = multipart(); app.post('/formdata',multipartMiddleware, function (req, res) { console.log(req.body); res.send("post successfully!"); });
3、application/json
body-parser中間件支持json解析, 添加中間件進(jìn)行解析即可
app.use(bodyParser.json());
4、text/xml
body-parser默認(rèn)不支持這種數(shù)據(jù)格式
解決方法:把請求體參數(shù)按照字符串讀取出來,然后使用 xml2json 包把字符串解析成json對象,然后對json對象進(jìn)行操作,方便得多。
注意:我們還是要使用 body-parse 得到字符串,然后再轉(zhuǎn)化.
利用req上定義的事件 data 來獲取http請求流, end 事件結(jié)束請求流的處理.
利用 xml2json 把上面得到的請求參數(shù)流(我們直接轉(zhuǎn)化為字符串)轉(zhuǎn)化為 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);
看完上述內(nèi)容,你們掌握node.js中怎么利用express解析post請求的方法了嗎?如果還想學(xué)到更多技能或想了解更多相關(guān)內(nèi)容,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,感謝各位的閱讀!