body-parser middleware
Node.js body parsing middleware
ハンドラの前に入ってくるリクエストボディをミドルウェアで解析し、req.bodyプロパティで
を利用できます。
注意 req. odyの形状はユーザーが制御する入力に基づいており、このオブジェクト内のすべての
プロパティと値は信頼できず、信頼する前に
検証する必要があります。 For example, req.body.foo.toString() may fail in multiple
ways, for example the foo property may not be there or may not be a string,
and toString may not be a function and instead a string or other user input.
Learn about the anatomy of an HTTP transaction in Node.js.
これは複合体であり、通常は 大きな性質のため、マルチパートbodyを扱いません。 マルチパートボディの場合、以下の モジュールに興味があるかもしれません。
このモジュールは以下のパーサを提供します。
あなたが興味を持っているかもしれない他のボディパーサ:
インストール
$ npm install body-parserAPI
// Import all parsersconst bodyParser = require('body-parser');
// Or import individual parsers directlyconst json = require('body-parser/json');const urlencoded = require('body-parser/urlencoded');const raw = require('body-parser/raw');const text = require('body-parser/text');bodyParser オブジェクトは、ミドルウェアを作成するために様々な工場を公開します。 All
middlewares will populate the req.body property with the parsed body when
the Content-Type request header matches the type option.
このモジュールによって返される様々なエラーは、 errors sectionで説明されています。
bodyParser.json([options])
Returns middleware that only parses json and only looks at requests where
the Content-Type header matches the type option. このパーサーは
Unicode エンコーディングを受け付け、gzip,
br, deflate エンコーディングの自動インフレーションをサポートしています。
ミドルウェアの後に request
オブジェクトに解析されたデータを含む新しいbody オブジェクトが追加されました。
オプション
The json function takes an optional options object that may contain any of
the following keys:
defaultCharset
リクエストの Content-Type ヘッダーに文字セットが
指定されていない場合、json コンテンツのデフォルト文字セットを指定します。 デフォルトは utf-8 です。
膨らませ
true に設定されている場合、デフレートされた(圧縮された)ボディは膨らまれます。
false の場合、デフレートされたボディは拒否されます。 デフォルトは true です。
制限
リクエストボディの最大サイズを制御します。 これが数値の場合、値
はバイト数を指定します。 文字列であれば、値はbytes ライブラリに渡され、解析します。 デフォルト
は '100kb' です。
可能な限り高い制限を設定し、可能な限りデフォルト値を使用しないことをお勧めします。 より大きなペイロードを許可すると、デコードと変換に必要なリソースのため、メモリ使用量が増加します。 より多くのデータが処理されるにつれて応答時間が長くなることもあります 「非常に高い」とは、例えば5MB以上のペイロードなど、デフォルトよりも高い値を意味しますが、既にこれらのリスクを導入し始めています。 デフォルトの制限では、これらの問題は発生しません。
reviver
2番目の
引数としてリバイバーオプションは直接JSON.parseに渡されます。 この引数
JSON.parseに関するMDN ドキュメント に詳しい情報があります。
厳格な
When set to true, will only accept arrays and objects; when false will
accept anything JSON.parse accepts. デフォルトは true です。
タイプ
type オプションは、ミドルウェアが
解析するメディアタイプを決定するために使用されます。 このオプションは文字列、文字列の配列、または関数です。 If not a
function, type option is passed directly to the
type-is library and this can
be an extension name (like json), a mime type (like application/json), or
a mime type with a wildcard (like */* or */json). 関数の場合、type
オプションはfn(req)と呼ばれ、リクエストは真の
値を返した場合に解析されます。 デフォルトは application/json です。
確認する
verify オプションを指定すると、verify(req, res, buf, encoding)と呼ばれます。
で、 buf は生のリクエストボディの Buffer で、 encoding はリクエストの
エンコーディングです。 エラーを投げることで解析を中止することができます。
bodyParser.raw([options])
全ての本文をBufferとして解析し、Content-Typeヘッダーがtypeオプションにマッチする
リクエストのみを参照するミドルウェアを返します。 この
パーサは、 gzip 、 br (brotli) 、 deflate
エンコーディングの自動インフレーションをサポートします。
ミドルウェアの後に request
オブジェクトに解析されたデータを含む新しいbody オブジェクトが追加されました。 これは本文の Buffer オブジェクト
になります。
オプション
The raw function takes an optional options object that may contain any of
the following keys:
膨らませ
true に設定されている場合、デフレートされた(圧縮された)ボディは膨らまれます。
false の場合、デフレートされたボディは拒否されます。 デフォルトは true です。
制限
リクエストボディの最大サイズを制御します。 これが数値の場合、値
はバイト数を指定します。 文字列であれば、値はbytes ライブラリに渡され、解析します。 デフォルト
は '100kb' です。
可能な限り高い制限を設定し、可能な限りデフォルト値を使用しないことをお勧めします。 より大きなペイロードを許可すると、デコードと変換に必要なリソースのため、メモリ使用量が増加します。 より多くのデータが処理されるにつれて応答時間が長くなることもあります 「非常に高い」とは、例えば5MB以上のペイロードなど、デフォルトよりも高い値を意味しますが、既にこれらのリスクを導入し始めています。 デフォルトの制限では、これらの問題は発生しません。
タイプ
type オプションは、ミドルウェアが
解析するメディアタイプを決定するために使用されます。 このオプションは文字列、文字列の配列、または関数です。
If not a function, type option is passed directly to the
type-is library and this
can be an extension name (like bin), a mime type (like
application/octet-stream), or a mime type with a wildcard (like */* or
application/*). 関数の場合、type オプションは fn(req)
と呼ばれ、リクエストは真の値を返す場合に解析されます。 デフォルトは
application/octet-stream です。
確認する
verify オプションを指定すると、verify(req, res, buf, encoding)と呼ばれます。
で、 buf は生のリクエストボディの Buffer で、 encoding はリクエストの
エンコーディングです。 エラーを投げることで解析を中止することができます。
bodyParser.text([options])
全ての本文を文字列として解析し、Content-Typeヘッダーがtypeオプションにマッチする
リクエストのみを参照するミドルウェアを返します。 この
パーサは、 gzip 、 br (brotli) 、 deflate
エンコーディングの自動インフレーションをサポートします。
ミドルウェアの後に request
オブジェクトに解析されたデータを含む新しいbody 文字列が追加されます。 これは、
本体の文字列になります。
オプション
The text function takes an optional options object that may contain any of
the following keys:
defaultCharset
リクエストの Content-Type ヘッダーに文字セットが
指定されていない場合、テキストコンテンツのデフォルト文字セットを指定します。 デフォルトは utf-8 です。
膨らませ
true に設定されている場合、デフレートされた(圧縮された)ボディは膨らまれます。
false の場合、デフレートされたボディは拒否されます。 デフォルトは true です。
制限
リクエストボディの最大サイズを制御します。 これが数値の場合、値
はバイト数を指定します。 文字列であれば、値はbytes ライブラリに渡され、解析します。 デフォルト
は '100kb' です。
可能な限り高い制限を設定し、可能な限りデフォルト値を使用しないことをお勧めします。 より大きなペイロードを許可すると、デコードと変換に必要なリソースのため、メモリ使用量が増加します。 より多くのデータが処理されるにつれて応答時間が長くなることもあります 「非常に高い」とは、例えば5MB以上のペイロードなど、デフォルトよりも高い値を意味しますが、既にこれらのリスクを導入し始めています。 デフォルトの制限では、これらの問題は発生しません。
タイプ
type オプションは、ミドルウェアが
解析するメディアタイプを決定するために使用されます。 このオプションは文字列、文字列の配列、または関数です。 If not
a function, type option is passed directly to the
type-is library and this can
be an extension name (like txt), a mime type (like text/plain), or a mime
type with a wildcard (like */* or text/*). 関数の場合、type
オプションはfn(req)と呼ばれ、
truthy値を返す場合はリクエストが解析されます。 デフォルトは text/plain です。
確認する
verify オプションを指定すると、verify(req, res, buf, encoding)と呼ばれます。
で、 buf は生のリクエストボディの Buffer で、 encoding はリクエストの
エンコーディングです。 エラーを投げることで解析を中止することができます。
bodyParser.urlencoded([options])
urlencoded ボディのみを解析し、Content-Type ヘッダーが type オプションに一致する場合の
リクエストのみを参照するミドルウェアを返します。 この
パーサは、ボディのUTF-8とISO-8859-1エンコーディングのみを受け付け、gzip、br(brotli)およびdeflateエンコーディングの
自動インフレーションをサポートします。
ミドルウェアの後に request
オブジェクトに解析されたデータを含む新しいbody オブジェクトが追加されました。 This object will contain
key-value pairs, where the value can be a string or array (when extended is
false), or any type (when extended is true).
オプション
The urlencoded function takes an optional options object that may contain
any of the following keys:
拡張
「拡張された」構文により、リッチオブジェクトや配列を URLエンコードされた形式にエンコードすることができ、JSONに似たURLエンコードを行うことができます。 の詳細については、qs libraryを参照してください。
デフォルトは false です。
膨らませ
true に設定されている場合、デフレートされた(圧縮された)ボディは膨らまれます。
false の場合、デフレートされたボディは拒否されます。 デフォルトは true です。
制限
リクエストボディの最大サイズを制御します。 これが数値の場合、値
はバイト数を指定します。 文字列であれば、値はbytes ライブラリに渡され、解析します。 デフォルト
は '100kb' です。
可能な限り高い制限を設定し、可能な限りデフォルト値を使用しないことをお勧めします。 より大きなペイロードを許可すると、デコードと変換に必要なリソースのため、メモリ使用量が増加します。 より多くのデータが処理されるにつれて応答時間が長くなることもあります 「非常に高い」とは、例えば5MB以上のペイロードなど、デフォルトよりも高い値を意味しますが、既にこれらのリスクを導入し始めています。 デフォルトの制限では、これらの問題は発生しません。
パラメータ制限
parameterLimit オプションは、URLでエンコードされたデータ内で
が許可されるパラメータの最大数を制御します。 リクエストにこの値よりも多くのパラメータ
が含まれている場合、413がクライアントに返されます。 デフォルトは 1000 です。
タイプ
type オプションは、ミドルウェアが
解析するメディアタイプを決定するために使用されます。 このオプションは文字列、文字列の配列、または関数です。 If not
a function, type option is passed directly to the
type-is library and this can
be an extension name (like urlencoded), a mime type (like
application/x-www-form-urlencoded), or a mime type with a wildcard (like
*/x-www-form-urlencoded). 関数の場合、typeオプションは
fn(req)と呼ばれ、リクエストは真の値を返した場合に解析されます。 デフォルト
は application/x-www-form-urlencoded です。
確認する
verify オプションを指定すると、verify(req, res, buf, encoding)と呼ばれます。
で、 buf は生のリクエストボディの Buffer で、 encoding はリクエストの
エンコーディングです。 エラーを投げることで解析を中止することができます。
defaultCharset
コンテンツ型で指定されていない場合、パースするデフォルトの文字セット。 Must be
either utf-8 or iso-8859-1. デフォルトは utf-8 です。
charsetSentinel
utf8パラメータの値を文字セット
セレクタとして優先するかどうか。 It requires the form to contain a parameter named utf8 with a value
of ✓. デフォルトは false です。
NumericEntities
Whether to decode numeric entities such as ☺ when parsing an iso-8859-1
form. デフォルトは false です。
深さ
depth オプションは、extended が true の場合、qs ライブラリの最大深度を設定するために使用されます。 これにより、パースされたキーの量を制限でき、特定のタイプの乱用を防ぐのに役立ちます。 デフォルトは 32 です。 この値をできるだけ低く保つことをお勧めします。
エラー
このモジュールで提供されるミドルウェアは、
http-errors モジュール を使用してエラーを生成します。 The errors
will typically have a status/statusCode property that contains the suggested
HTTP response code, an expose property to determine if the message property
should be displayed to the client, a type property to determine the type of
error without matching against the message, and a body property containing
the read body, if available.
以下は一般的なエラーですが、さまざまな理由で を介してエラーが発生する可能性があります。
コンテンツエンコーディングはサポートされていません
このエラーは、
にエンコーディングが含まれていて、“inflation” オプションが false に設定されている Content-Encoding ヘッダーがリクエストに含まれていた場合に発生します。 The
status property is set to 415, the type property is set to
'encoding.unsupported', and the charset property will be set to the
encoding that is unsupported.
エンティティの解析に失敗しました
This error will occur when the request contained an entity that could not be
parsed by the middleware. The status property is set to 400, the type
property is set to 'entity.parse.failed', and the body property is set to
the entity value that failed parsing.
エンティティの検証に失敗しました
このエラーは、定義された verify オプションで
失敗した検証に失敗したエンティティがリクエストに含まれている場合に発生します。 The status property is
set to 403, the type property is set to 'entity.verify.failed', and the
body property is set to the entity value that failed verification.
リクエストは中止されました
このエラーは、
本文を読み込む前に、リクエストがクライアントによって中止された場合に発生します。 The received property will be set to the number of
bytes before the request was aborted and the expected property is
set to the number of expected bytes. status プロパティは 400
に設定され、type プロパティは 'request.aborted' に設定されます。
要求エンティティが大きすぎます
このエラーは、リクエストボディのサイズが “limit”
オプションより大きい場合に発生します。 limit プロパティはバイト制限に設定され、length
プロパティはリクエスト本体の長さに設定されます。 status プロパティは
に設定されており、type プロパティは entity.too.large' に設定されています。
要求サイズがコンテンツの長さと一致しません
このエラーは、リクエストの長さが Content-Length ヘッダの
の長さと一致しなかった場合に発生します。 これは通常、リクエストが不正な形式になったときに発生します。
通常、バイトではなく
文字に基づいて Content-Length ヘッダーが計算されたときです。 statusプロパティは400に、typeプロパティ
は'request.size.invalid'に設定されています。
ストリームのエンコーディングを設定できません
このエラーは、このミドルウェアの
より前に req.setEncoding メソッドと呼ばれるものが発生します。 This module operates directly on bytes only and you cannot
call req.setEncoding when using this module. status プロパティは
500 に設定され、type プロパティは 'stream.encoding.set' に設定されます。
ストリームが読み込めません
このエラーは、このミドルウェア
が読み込みを試みたときにリクエストが読み取れなくなったときに発生します。 これは通常、このモジュールがリクエスト本文を読み込んだ
ミドルウェア以外のものを意味し、ミドルウェアも
同じリクエストを読み込むように設定されています。 status プロパティは 500 に設定され、type
プロパティは 'stream.not.readable' に設定されます。
パラメータが多すぎます
このエラーは、リクエストのコンテンツが urlencoded parserの設定された
parameterLimit を超えた場合に発生します。 status プロパティは
413 に設定され、type プロパティは 'parameters.too.many' に設定されます。
未サポートの文字セット “BOGUS”
This error will occur when the request had a charset parameter in the
Content-Type header, but the iconv-lite module does not support it OR the
parser does not support it. charset は charset プロパティと同様に
メッセージにも含まれています。 The status property is set to 415, the
type property is set to 'charset.unsupported', and the charset property
is set to the charset that is unsupported.
サポートされていないコンテンツエンコーディング”bogus”
このエラーは、リクエストに
サポートされていないエンコーディングが含まれている Content-Encoding ヘッダーがある場合に発生します。 エンコーディングは
メッセージと encoding プロパティに含まれます。 The status property is set to 415,
the type property is set to 'encoding.unsupported', and the encoding
property is set to the encoding that is unsupported.
入力が深さを超えました
このエラーは、extended プロパティが true に設定されている bodyParser.urlencoded を使用し、入力が設定された depth オプションを超えた場合に発生します。 status プロパティは 400 に設定されています。 depthオプションを確認し、より高い値が必要かどうかを評価することをお勧めします。 depthオプションが32(デフォルト値)に設定されている場合、エラーはスローされません。
例
Express/Connect トップレベルジェネリック
この例では、ジェネリックな JSON と URL エンコードされたパーサを トップレベルのミドルウェアとして追加し、すべてのリクエストの本文をパースします。 これは最も単純な設定です。
const express = require('express');const bodyParser = require('body-parser');
const app = express();
// parse application/x-www-form-urlencodedapp.use(bodyParser.urlencoded());
// parse application/jsonapp.use(bodyParser.json());
app.use(function (req, res) { res.setHeader('Content-Type', 'text/plain'); res.write('you posted:\n'); res.end(String(JSON.stringify(req.body, null, 2)));});エクスプレスルート固有のルート
この例では、 が必要とするルートにボディパーサを追加することを示します。 一般に、これは Expressでbody-parserを使用するために最も推奨される方法です。
const express = require('express');const bodyParser = require('body-parser');
const app = express();
// create application/json parserconst jsonParser = bodyParser.json();
// create application/x-www-form-urlencoded parserconst urlencodedParser = bodyParser.urlencoded();
// POST /login gets urlencoded bodiesapp.post('/login', urlencodedParser, function (req, res) { if (!req.body || !req.body.username) res.sendStatus(400); res.send('welcome, ' + req.body.username);});
// POST /api/users gets JSON bodiesapp.post('/api/users', jsonParser, function (req, res) { if (!req.body) res.sendStatus(400); // create user in req.body});Parserの許容タイプの変更
全てのパーサーは、ミドルウェアが解析する
Content-Type を変更することができるtype オプションを受け付けます。
const express = require('express');const bodyParser = require('body-parser');
const app = express();
// parse various different custom JSON types as JSONapp.use(bodyParser.json({ type: 'application/*+json' }));
// parse some custom thing into a Bufferapp.use(bodyParser.raw({ type: 'application/vnd.custom-type' }));
// parse an HTML body into a stringapp.use(bodyParser.text({ type: 'text/html' }));