Skip to main content

Compress responses in your Flask app with gzip, deflate, brotli or zstandard.

Project description

Flask-Compress

Build Version Downloads

Flask-Compress allows you to easily compress your Flask application's responses with gzip, deflate, brotli or zstd. It originally started as a fork of Flask-gzip. Supported Python versions are 3.9 and newer.

The preferred solution is to have a server (like Nginx) automatically compress the static files for you. If you don't have that option Flask-Compress will solve the problem for you.

How it works

Flask-Compress both adds the various headers required for a compressed response and compresses the response data. This makes serving compressed static files extremely easy.

Internally, every time a request is made the extension will check if it matches one of the compressible MIME types and whether the client and the server use some common compression algorithm, and will automatically attach the appropriate headers.

To determine the compression algorithm, the Accept-Encoding request header is inspected, respecting the quality factor as described in MDN docs. If no requested compression algorithm is supported by the server, we don't compress the response. If, on the other hand, multiple suitable algorithms are found and are requested with the same quality factor, we choose the first one defined in the COMPRESS_ALGORITHM option (see below).

Installation

If you use pip then installation is simply:

$ pip install flask-compress

or, if you want the latest github version:

$ pip install git+git://github.com/colour-science/flask-compress.git

Using Flask-Compress

Globally

Flask-Compress is incredibly simple to use. In order to start compressing your Flask application's assets, the first thing to do is let Flask-Compress know about your flask.Flask application object.

from flask import Flask
from flask_compress import Compress

app = Flask(__name__)
Compress(app)

In many cases, however, one cannot expect a Flask instance to be ready at import time, and a common pattern is to return a Flask instance from within a function only after other configuration details have been taken care of. In these cases, Flask-Compress provides a simple function, flask_compress.Compress.init_app, which takes your application as an argument.

from flask import Flask
from flask_compress import Compress

compress = Compress()

def start_app():
    app = Flask(__name__)
    compress.init_app(app)
    return app

In terms of automatically compressing your assets, passing your flask.Flask object to the flask_compress.Compress object is all that needs to be done.

Per-view compression

Compression is possible per view using the @compress.compressed() decorator. Make sure to disable global compression first.

from flask import Flask
from flask_compress import Compress

app = Flask(__name__)
app.config["COMPRESS_REGISTER"] = False  # disable default compression of all eligible requests
compress = Compress()
compress.init_app(app)

# Compress this view specifically
@app.route("/test")
@compress.compressed()
def view():
   pass

Cache example

Flask-Compress can be integrated with caching mechanisms to serve compressed responses directly from the cache. This can significantly reduce server load and response times. Here is an example of how to configure Flask-Compress with caching using Flask-Caching. The example demonstrates how to create a simple cache instance with a 1-hour timeout, and use it to cache compressed responses for incoming requests.

from flask import Flask
from flask_compress import Compress
from flask_cache import Cache

# Initializing flask app
app = Flask(__name__)

cache = Cache(config={
    'CACHE_TYPE': 'SimpleCache',
    'CACHE_DEFAULT_TIMEOUT': 60*60  # 1 hour cache timeout
})
cache.init_app(app)

# Define a function to return cache key for incoming requests
def get_cache_key(request):
    return request.url

# Initialize Flask-Compress
compress = Compress()
compress.init_app(app)

# Set up cache for compressed responses
compress.cache = cache
compress.cache_key = get_cache_key

If you do not want to pull an external dependency, you can use a simple in-memory cache using compress.cache = flask_compress.DictCache().

ETag support

Flask-Compress supports ETag headers for conditional requests. When a client makes a request with an If-None-Match header, Flask-Compress will evaluate the ETag and return a 304 Not Modified response if the resource has not changed. This helps to reduce bandwidth usage and improve performance for clients that support caching.

To disable ETag support, set the COMPRESS_EVALUATE_CONDITIONAL_REQUEST configuration option to False in your Flask application settings.

For streaming responses, ETag support is disabled by default, as this effectively requires buffering the entire response in memory to compute the ETag. If you want to enable ETag support for streaming responses, you can add the endpoint name to the COMPRESS_STREAMING_ENDPOINT_CONDITIONAL configuration option, which defaults to ["static"] for static files served by Flask.

Streaming support

Flask-Compress supports compressing streaming responses. By default, streaming responses are compressed using the algorithms specified in the COMPRESS_ALGORITHM_STREAMING configuration option.

To disable streaming compression, set the COMPRESS_STREAMS configuration option to False in your Flask application settings.

As mentioned above, ETag support is disabled by default for streaming responses. If you want to enable it for specific endpoints, you can add the endpoint name to the COMPRESS_STREAMING_ENDPOINT_CONDITIONAL configuration option, but this will require buffering the entire response in memory to compute the ETag.

Options

Within your Flask application's settings you can provide the following settings to control the behavior of Flask-Compress. None of the settings are required.

Option Description Default
COMPRESS_MIMETYPES Set the list of mimetypes to compress here. [
'text/html',
'text/css',
'text/plain',
'text/xml',
'text/x-component',
'text/javascript',
'application/x-javascript',
'application/javascript',
'application/json',
'application/manifest+json',
'application/vnd.api+json',
'application/xml',
'application/xhtml+xml',
'application/rss+xml',
'application/atom+xml',
'application/vnd.ms-fontobject',
'application/x-font-ttf',
'application/x-font-opentype',
'application/x-font-truetype',
'image/svg+xml',
'image/x-icon',
'image/vnd.microsoft.icon',
'font/ttf',
'font/eot',
'font/otf',
'font/opentype',
]
COMPRESS_LEVEL Specifies the gzip compression level. 6
COMPRESS_BR_LEVEL Specifies the Brotli compression level. Ranges from 0 to 11. 4
COMPRESS_BR_MODE For Brotli, the compression mode. The options are 0, 1, or 2. These correspond to "generic", "text" (for UTF-8 input), and "font" (for WOFF 2.0). 0
COMPRESS_BR_WINDOW For Brotli, this specifies the base-2 logarithm of the sliding window size. Ranges from 10 to 24. 22
COMPRESS_BR_BLOCK For Brotli, this provides the base-2 logarithm of the maximum input block size. If zero is provided, value will be determined based on the quality. Ranges from 16 to 24. 0
COMPRESS_ZSTD_LEVEL Specifies the ZStandard compression level. Ranges from 1 to 22. Levels >= 20, labeled ultra, should be used with caution, as they require more memory. 0 means use the default level. -131072 to -1, negative levels extend the range of speed vs ratio preferences. The lower the level, the faster the speed, but at the cost of compression ratio. 3
COMPRESS_DEFLATE_LEVEL Specifies the deflate compression level. -1
COMPRESS_MIN_SIZE Specifies the minimum file size threshold for compressing files. 500
COMPRESS_CACHE_KEY Specifies the cache key method for lookup/storage of response data. None
COMPRESS_CACHE_BACKEND Specified the backend for storing the cached response data. None
COMPRESS_REGISTER Specifies if compression should be automatically registered. True
COMPRESS_ALGORITHM Supported compression algorithms. ['zstd', 'br', 'gzip', 'deflate']
COMPRESS_ALGORITHM_STREAMING Supported compression algorithms for streaming. ['zstd', 'br', 'deflate']
COMPRESS_STREAMS Compress streaming responses. True
COMPRESS_EVALUATE_CONDITIONAL_REQUEST Compress evaluates conditional requests. True
COMPRESS_STREAMING_ENDPOINT_CONDITIONAL Streaming endpoints where we evaluate conditional requests. ["static"]

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

flask_compress-1.24.tar.gz (21.1 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

flask_compress-1.24-py3-none-any.whl (11.0 kB view details)

Uploaded Python 3

File details

Details for the file flask_compress-1.24.tar.gz.

File metadata

  • Download URL: flask_compress-1.24.tar.gz
  • Upload date:
  • Size: 21.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for flask_compress-1.24.tar.gz
Algorithm Hash digest
SHA256 14097cefe59ecb3e466d52a6aeb62f34f125a9f7dadf1f33a53e430ce4a50f31
MD5 b8e065808437ba7127a9378a847b428e
BLAKE2b-256 c2de2ae0118051b38ab53437328074a696f3ee7d61e15bf7454b78a3088e5bc3

See more details on using hashes here.

Provenance

The following attestation bundles were made for flask_compress-1.24.tar.gz:

Publisher: ci.yaml on colour-science/flask-compress

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file flask_compress-1.24-py3-none-any.whl.

File metadata

  • Download URL: flask_compress-1.24-py3-none-any.whl
  • Upload date:
  • Size: 11.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for flask_compress-1.24-py3-none-any.whl
Algorithm Hash digest
SHA256 1e63668eb6e3242bd4f6ad98825a924e3984409be90c125477893d586007d00c
MD5 ac1974091c47f88bd46b58aab45395e6
BLAKE2b-256 4c0ffe51e0b2301bbd429af44273a923ff92127b18d13abba5ae5a1d60e8e497

See more details on using hashes here.

Provenance

The following attestation bundles were made for flask_compress-1.24-py3-none-any.whl:

Publisher: ci.yaml on colour-science/flask-compress

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page