--- title: encode (Caddyfile directive) --- # encode Encodes responses using the configured encoding(s). A typical use for encoding is compression. ## Syntax ```caddy-d encode [] { # encoding formats gzip [] zstd minimum_length # response matcher single line syntax match [header []] | [status ] # or response matcher block for multiple conditions match { status header [] } } ``` - **<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. - **gzip** enables Gzip compression, optionally at the specified level. - **zstd** enables Zstandard compression. - **minimum_length** the minimum number of bytes a response should have to be encoded (default: 512). - **match** is a [response matcher](#response-matcher). Only matching responses are encoded. The default looks like this: ```caddy-d match { 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/* } ``` ## Response matcher **Response matchers** can be used to filter (or classify) responses by specific criteria. ### status ```caddy-d status ``` 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 ### header See the [header](/docs/caddyfile/matchers#header) request matcher for the supported syntax. ## Examples Enable Gzip compression: ```caddy-d encode gzip ``` Enable Zstandard and Gzip compression (with Zstandard implicitly preferred, since it is first): ```caddy-d encode zstd gzip ``` And in a full site, compressing static files served by [`file_server`](file_server): ```caddy example.com { root * /srv encode zstd gzip file_server } ```