You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
82 lines
3.2 KiB
82 lines
3.2 KiB
3 years ago
|
<h1 align="center">Fastify</h1>
|
||
|
|
||
|
## Request
|
||
|
The first parameter of the handler function is `Request`.
|
||
|
|
||
|
Request is a core Fastify object containing the following fields:
|
||
|
- `query` - the parsed querystring, its format is specified by
|
||
|
[`querystringParser`](./Server.md#querystringparser)
|
||
|
- `body` - the request payload, see [Content-Type
|
||
|
Parser](./ContentTypeParser.md) for details on what request payloads Fastify
|
||
|
natively parses and how to support other content types
|
||
|
- `params` - the params matching the URL
|
||
|
- [`headers`](#headers) - the headers getter and setter
|
||
|
- `raw` - the incoming HTTP request from Node core
|
||
|
- `req` *(deprecated, use `.raw` instead)* - the incoming HTTP request from Node
|
||
|
core
|
||
|
- `server` - The Fastify server instance, scoped to the current [encapsulation
|
||
|
context](./Encapsulation.md)
|
||
|
- `id` - the request ID
|
||
|
- `log` - the logger instance of the incoming request
|
||
|
- `ip` - the IP address of the incoming request
|
||
|
- `ips` - an array of the IP addresses, ordered from closest to furthest, in the
|
||
|
`X-Forwarded-For` header of the incoming request (only when the
|
||
|
[`trustProxy`](./Server.md#factory-trust-proxy) option is enabled)
|
||
|
- `hostname` - the host of the incoming request (derived from `X-Forwarded-Host`
|
||
|
header when the [`trustProxy`](./Server.md#factory-trust-proxy) option is
|
||
|
enabled). For HTTP/2 compatibility it returns `:authority` if no host header
|
||
|
exists.
|
||
|
- `protocol` - the protocol of the incoming request (`https` or `http`)
|
||
|
- `method` - the method of the incoming request
|
||
|
- `url` - the URL of the incoming request
|
||
|
- `routerMethod` - the method defined for the router that is handling the
|
||
|
request
|
||
|
- `routerPath` - the path pattern defined for the router that is handling the
|
||
|
request
|
||
|
- `is404` - true if request is being handled by 404 handler, false if it is not
|
||
|
- `connection` - Deprecated, use `socket` instead. The underlying connection of
|
||
|
the incoming request.
|
||
|
- `socket` - the underlying connection of the incoming request
|
||
|
- `context` - A Fastify internal object. You should not use it directly or
|
||
|
modify it. It is useful to access one special key:
|
||
|
- `context.config` - The route [`config`](./Routes.md#routes-config) object.
|
||
|
|
||
|
### Headers
|
||
|
|
||
|
The `request.headers` is a getter that returns an Object with the headers of the
|
||
|
incoming request. You can set custom headers like this:
|
||
|
|
||
|
```js
|
||
|
request.headers = {
|
||
|
'foo': 'bar',
|
||
|
'baz': 'qux'
|
||
|
}
|
||
|
```
|
||
|
|
||
|
This operation will add to the request headers the new values that can be read
|
||
|
calling `request.headers.bar`. Moreover, you can still access the standard
|
||
|
request's headers with the `request.raw.headers` property.
|
||
|
|
||
|
> Note: For performance reason on `not found` route, you may see that we will add
|
||
|
an extra property `Symbol('fastify.RequestAcceptVersion')` on the headers.
|
||
|
|
||
|
```js
|
||
|
fastify.post('/:params', options, function (request, reply) {
|
||
|
console.log(request.body)
|
||
|
console.log(request.query)
|
||
|
console.log(request.params)
|
||
|
console.log(request.headers)
|
||
|
console.log(request.raw)
|
||
|
console.log(request.server)
|
||
|
console.log(request.id)
|
||
|
console.log(request.ip)
|
||
|
console.log(request.ips)
|
||
|
console.log(request.hostname)
|
||
|
console.log(request.protocol)
|
||
|
console.log(request.url)
|
||
|
console.log(request.routerMethod)
|
||
|
console.log(request.routerPath)
|
||
|
request.log.info('some info')
|
||
|
})
|
||
|
```
|