2020-01-24 12:47:52 -07:00
---
title: encode (Caddyfile directive)
---
2021-08-31 14:50:01 -04:00
< script >
2023-09-07 14:18:30 -04:00
window.$(function() {
2021-08-31 14:50:01 -04:00
// We'll add links to all the subdirectives if a matching anchor tag is found on the page.
addLinksToSubdirectives();
});
< / script >
2020-01-24 12:47:52 -07:00
# encode
Encodes responses using the configured encoding(s). A typical use for encoding is compression.
## Syntax
2020-05-17 16:32:12 -04:00
```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
2021-04-05 23:24:54 +02: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
2021-04-05 23:24:54 +02:00
match {
status < code... >
header < field > [< value > ]
}
2020-01-24 12:47:52 -07:00
}
```
2021-05-10 13:43:20 -06:00
- **< formats...> ** 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.
2023-08-29 18:47:54 -04:00
2021-08-31 14:50:01 -04:00
- **gzip** < span id = "gzip" /> enables Gzip compression, optionally at the specified level.
2023-08-29 18:47:54 -04:00
2021-08-31 14:50:01 -04:00
- **zstd** < span id = "zstd" /> enables Zstandard compression.
2023-08-29 18:47:54 -04:00
2021-08-31 14:50:01 -04:00
- **minimum_length** < span id = "minimum_length" /> the minimum number of bytes a response should have to be encoded (default: 512).
2023-08-29 18:47:54 -04:00
2021-08-31 14:50:01 -04:00
- **match** < span id = "match" /> is a [response matcher ](#response-matcher ). Only matching responses are encoded. The default looks like this:
2021-04-05 23:24:54 +02:00
```caddy-d
match {
2024-05-29 18:18:32 -04:00
header Content-Type application/atom+xml*
header Content-Type application/eot*
header Content-Type application/font*
header Content-Type application/geo+json*
header Content-Type application/graphql+json*
header Content-Type application/javascript*
header Content-Type application/json*
header Content-Type application/ld+json*
header Content-Type application/manifest+json*
header Content-Type application/opentype*
header Content-Type application/otf*
header Content-Type application/rss+xml*
header Content-Type application/truetype*
header Content-Type application/ttf*
header Content-Type application/vnd.api+json*
header Content-Type application/vnd.ms-fontobject*
header Content-Type application/wasm*
header Content-Type application/x-httpd-cgi*
header Content-Type application/x-javascript*
header Content-Type application/x-opentype*
header Content-Type application/x-otf*
header Content-Type application/x-perl*
header Content-Type application/x-protobuf*
header Content-Type application/x-ttf*
header Content-Type application/xhtml+xml*
header Content-Type application/xml*
header Content-Type font/*
header Content-Type image/svg+xml*
header Content-Type image/vnd.microsoft.icon*
header Content-Type image/x-icon*
header Content-Type multipart/bag*
header Content-Type multipart/mixed*
header Content-Type text/*
2021-04-05 23:24:54 +02:00
}
```
2024-02-20 06:49:30 -05:00
2021-04-05 23:24:54 +02:00
## Response matcher
**Response matchers** can be used to filter (or classify) responses by specific criteria.
2024-02-20 06:49:30 -05:00
2021-04-05 23:24:54 +02:00
### status
```caddy-d
status < code... >
```
2020-01-24 12:47:52 -07:00
2021-04-05 23:24:54 +02:00
By HTTP status code.
- **< code...> ** 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
2024-02-20 06:49:30 -05:00
2021-04-05 23:24:54 +02:00
### header
2021-05-12 15:21:32 -04:00
See the [header ](/docs/caddyfile/matchers#header ) request matcher for the supported syntax.
2020-01-24 12:47:52 -07:00
2024-02-20 06:49:30 -05:00
2020-01-24 12:47:52 -07:00
## Examples
Enable Gzip compression:
2020-05-17 16:32:12 -04:00
```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
2020-05-17 16:32:12 -04:00
```caddy-d
2020-01-24 12:47:52 -07:00
encode zstd gzip
```
2024-02-20 06:49:30 -05:00
And in a full site, compressing static files served by [`file_server` ](file_server ):
```caddy
example.com {
root * /srv
encode zstd gzip
file_server
}
```