You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
A simple plugin for Fastify that adds a content type parser for
the content type application/x-www-form-urlencoded.
Install
npm i @fastify/formbody
Compatibility
Plugin version
Fastify version
^8.x
^5.x
^7.x
^4.x
^6.x
^3.x
^3.x
^2.x
^2.x
^1.x
Please note that if a Fastify version is out of support, then so are the corresponding versions of this plugin
in the table above.
See Fastify's LTS policy for more details.
The plugin accepts an options object with the following properties:
bodyLimit: The maximum amount of bytes to process
before returning an error. If the limit is exceeded, a 500 error will be
returned immediately. When set to undefined the limit will be set to whatever
is configured on the parent Fastify instance. The default value is
whatever is configured in
fastify
(1048576 by default).
parser: The default parser used is the querystring.parse built-in. You can change this default by passing a parser function e.g. fastify.register(require('@fastify/formbody'), { parser: str => myParser(str) })
Upgrading from 4.x
Previously, the external qs lib was used that did things like parse nested objects. For example:
Input:foo[one]=foo&foo[two]=bar
Parsed:{ foo: { one: 'foo', two: 'bar' } }
The way this is handled now using the built-in querystring.parse:
Input:foo[one]=foo&foo[two]=bar
Parsed:{ 'foo[one]': 'foo', 'foo[two]': 'bar' }
If you need nested parsing, you must configure it manually by installing the qs lib (npm i qs), and then configure an optional parser: