Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/koajs/body-parsers
collection of koa body parsers
https://github.com/koajs/body-parsers
Last synced: 2 months ago
JSON representation
collection of koa body parsers
- Host: GitHub
- URL: https://github.com/koajs/body-parsers
- Owner: koajs
- License: mit
- Created: 2014-06-13T03:03:47.000Z (over 10 years ago)
- Default Branch: master
- Last Pushed: 2024-04-11T16:28:01.000Z (8 months ago)
- Last Synced: 2024-04-14T13:08:39.043Z (8 months ago)
- Language: JavaScript
- Size: 139 KB
- Stars: 38
- Watchers: 4
- Forks: 10
- Open Issues: 3
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-koa - koa-body-parsers - Koa请求正文解析器集合。![](https://img.shields.io/github/stars/koajs/koa-body-parsers.svg?style=social&label=Star) ![](https://img.shields.io/npm/dm/koa-body-parsers.svg?style=flat-square) (仓库 / 中间件)
- awesome-koa - body-parsers - collection of koa body parsers (Middleware)
README
# Koa Body Parsers
[![NPM version][npm-image]][npm-url]
A more functional version of body parsing.
Use this module if you want to "lazily" parse the body.
Other middleware automatically parse the body in the middleware chain, which might not be ideal as business logic like authentication, authorization, and routing are not done prior to body parsing.Includes a `json` and `urlencoded` parsers.
## API
Initialization:
```js
import koaBodyParsers from 'koa-body-parsers'
import Koa from 'koa'const app = new Koa()
koaBodyParsers(app)// example usage
app.use(async (ctx) => {
const currentUser = UserService.getCurrentUser(ctx)
ctx.assert(currentUser, 401)ctx.assert(ctx.request.is('json'), 415)
const body = await ctx.request.json('100kb')
ctx.body = body
})
```Because this module is a plugin for the `context`, the API signature is different.
### Expect: 100-continue and ctx.response.writeContinue()
`Expect: 100-continue` is automatically supported as long as you use `app.listen()`.
Otherwise, create your server like this:```js
const fn = app.callback();
const server = http.createServer(); // or whatever server you use
server.on('request', fn); // regular requests
server.on('checkContinue', function (req, res) {
// tag requests with `Expect: 100-continue`
req.checkContinue = true;
fn(req, res);
});
```If `Expect: 100-continue` was sent to the client,
this will automatically response with a "100-continue".
Use this right before parsing the body.
Automatically called by all following body parsers,
but you would still have to call it if you're doing something like:```js
app.use(async (ctx) => {
if (ctx.request.is('image/*')) {
ctx.response.writeContinue();
const buffer = await ctx.request.buffer()
}
})
```### const body = await ctx.request.json([limit])
Get the JSON body of the request, if any.
`limit` defaults to `100kb`.### const body = await ctx.request.urlencoded([limit])
Get the traditional form body of the request, if any,
`limit` defaults to `100kb`.### const text = await ctx.request.text([limit])
Get the body of the request as a single `text` string.
`limit` defaults to `100kb`.
You could use this to create your own request body parser of some sort.### const buffer = await ctx.request.buffer([limit])
Get the body of the request as a single `Buffer` instance.
`limit` defaults to `1mb`.[npm-image]: https://img.shields.io/npm/v/koa-body-parsers.svg?style=flat-square
[npm-url]: https://npmjs.org/package/koa-body-parsers