安裝
$ npm install body-parser
API
var bodyPaeser =require('body-parser')
可以通過body-parser 對象創(chuàng)建中間件,當接收到客戶端請求時所有的中間件都會給req.body 添加屬性,請求體為空,則解析為空{(diào)} (或者出現(xiàn)錯誤)。
bodyParser.json(options)
中間件只會解析 json ,允許請求提任意Unicode編碼支持 gzip 和 deflate 編碼。
options
一個對象,有以下屬性
inflate
默認為false,true->壓縮的請求體會被解壓,false->壓縮的請求提不被解壓。
limit
控制請求體最大大小,默認為100kb,當為數(shù)字時會轉換為bytes,當為字符串時,value值會通過 bytes庫 轉換為字節(jié)大小。
reviver
此選項會通過JSON.parse直接傳給其第二個參數(shù)。
strict
默認為true,當為true時只接受數(shù)組和對象,當為false時會接受任何JSON.parse 能接受的。
type
type 選項用來決定中間件要解析媒體類型。選項可以是一個函數(shù)或者是字符串。當為字符串時,可以直接通過type-is 庫直接傳遞給選項,字符串也可以為一個擴展名(例如json)、mime 類型(application/json、/ 、*/json)。當為函數(shù)時:默認為application/json。
verify
verify選項,若缺失則為一個函數(shù)function(req,res,buf,encoding),buf為一個Buffer。
bodyParse.raw(option)
將請求體內(nèi)容作為Buffer來處理,并返回。支持gzip deflate 壓縮。
inflate
limit
type
verify
bodyParser.text(option)
將請求提內(nèi)容作為字符串來處理,并返回。支持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
舉例:
const express=require('express'); const bodyParser=require('body-parser'); var server=express(); server.listen(8080); server.use(bodyParser.urlencoded({ extended: false, //擴展模式 limit: 2*1024*1024 //限制-2M })); server.use('/', function (req, res){ console.log(req.body); //POST //req.query GET //req.body POST });
html代碼:
<form action="http://localhost:8080" method="post"> 用戶:<input type="text" name="user" /><br> 密碼:<input type="password" name="pass" /><br> <input type="submit" value="提交" >
以上這篇nodejs body-parser 解析post數(shù)據(jù)實例就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。
聲明:本網(wǎng)頁內(nèi)容旨在傳播知識,若有侵權等問題請及時與本網(wǎng)聯(lián)系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com