caddy-website/src/docs/markdown/caddyfile/directives/encode.md

78 lines
2 KiB
Markdown
Raw Normal View History

2020-01-24 12:47:52 -07:00
---
title: encode (Caddyfile directive)
---
# encode
Encodes responses using the configured encoding(s). A typical use for encoding is compression.
## Syntax
```caddy-d
2020-01-24 12:47:52 -07:00
encode [<matcher>] <formats...> {
2021-05-10 13:43:20 -06:00
# encoding formats
2020-01-24 12:47:52 -07:00
gzip [<level>]
zstd
2021-05-10 13:43:20 -06:00
minimum_length <length>
# response matcher single line syntax
match [header <field> [<value>]] | [status <code...>]
2021-05-10 13:43:20 -06:00
# or response matcher block for multiple conditions
match {
status <code...>
header <field> [<value>]
}
2020-01-24 12:47:52 -07:00
}
```
2021-05-10 13:43:20 -06:00
- **&lt;formats...&gt;** is the list of encoding formats to enable. If multiple encodings are enabled, the encoding is chosen based the request's Accept-Encoding header; if the client has no strong preference (q-factor), then the first supported encoding is used.
2020-01-24 12:47:52 -07:00
- **gzip** enables Gzip compression, optionally at the specified level.
- **zstd** enables Zstandard compression.
2021-05-10 13:43:20 -06:00
- **minimum_length** the minimum number of bytes a response should have to be encoded (default: 512).
- **match** is a [Response matcher](#responsematcher). Only matching Responses are encoded. The default looks like this:
```caddy-d
match {
header Content-Type text/*
header Content-Type application/json*
header Content-Type application/javascript*
header Content-Type application/xhtml+xml*
header Content-Type application/atom+xml*
header Content-Type application/rss+xml*
header Content-Type image/svg+xml*
}
```
## Response matcher
**Response matchers** can be used to filter (or classify) responses by specific criteria.
### status
```caddy-d
status <code...>
```
2020-01-24 12:47:52 -07:00
By HTTP status code.
- **&lt;code...&gt;** is a list of HTTP status codes. Special cases are `2xx`, `3xx`, ... which match against all status codes in the range of 200-299, 300-399, ... respectively
### header
See Request matcher [header](/docs/caddyfile/matchers#header).
2020-01-24 12:47:52 -07:00
## Examples
Enable Gzip compression:
```caddy-d
2020-01-24 12:47:52 -07:00
encode gzip
```
2021-05-10 13:43:20 -06:00
Enable Zstandard and Gzip compression (with Zstandard implicitly preferred, since it is first):
2020-01-24 12:47:52 -07:00
```caddy-d
2020-01-24 12:47:52 -07:00
encode zstd gzip
```