koa-parser
TypeScript icon, indicating that this package has built-in type declarations

1.0.8 • Public • Published

koa-parserBuild Status

a body parser for koa. support json, form(urlencoded), multipart and text type body.

Install

NPM

Usage

const Koa = require('koa')
const parser = require('koa-parser')
 
const port = 3000
const app = new Koa()
 
app.use(parser())
 
app.use(async (ctx, next) => {
  // if nothing was parsed, body will be undefined
  if (ctx.request.body !== undefined) {
    ctx.body = ctx.request.body
  }
  await next()
})
 
app.listen(port)
console.error(`listening on port ${port}`)

Screenshot

default options

Options

app.use(parser({
  encoding?: string, // requested encoding
  error?: (err: any, ctx: Koa.Context) => any, // support custom parser error handle
  json?: string | string[], // support json parser types
  multipart?: string | string[], // support multipart(form-data) parser types
  text?: string | string[], // support text parser types
  urlencoded?: string | string[] // support urlencoded(form) parser types
}))
  • encoding: requested encoding. Default is utf-8

  • error: support custom error handle, Default is false. if koa-bodyparser throw an error, you can customize the response like:

    app.use(parser({
      error (err, ctx) {
        console.log(err)
        ctx.throw(err, 422)
      }
    }))
  • json: Extended support for json parsing options, The default supported types are ['application/json', 'application/json-patch+json', 'application/vnd.api+json', 'application/csp-report']. you can customize the type like:

    // json will be support default types and application/x-javascript
    app.use(parser({
      json: 'application/x-javascript' // You can also pass parameters in an array
    }))
  • multipart: Extended support for multipart(form-data) parsing options, The default supported types are ['multipart/form-data']

  • text: Extended support for text parsing options, The default supported types are ['text/plain']

  • urlencoded: Extended support for urlencoded(form) parsing options, The default supported types are ['application/x-www-form-urlencoded']

Licences

MIT

Versions

Current Tags

VersionDownloads (Last 7 Days)Tag
1.0.821latest

Version History

VersionDownloads (Last 7 Days)Published
1.0.821
1.0.70
1.0.60
1.0.51
1.0.40
1.0.30
1.0.20
1.0.10
0.4.20
0.4.11
0.4.00
0.3.00
0.2.80
0.1.01
0.0.20
0.0.10

Package Sidebar

Install

npm i koa-parser

Weekly Downloads

26

Version

1.0.8

License

MIT

Unpacked Size

115 kB

Total Files

10

Last publish

Collaborators

  • nashaofu