Parse and generate Content-Disposition headers
Project description
rfc6266
This module parses and generates HTTP Content-Disposition headers. These headers are used when getting resources for download; they provide a hint of whether the file should be downloaded, and of what filename to use when saving.
Usage
Receiver
parse_headers builds a ContentDisposition object from the Content-Disposition header and (as a fallback) the document location. Shortcuts work with response objects from httplib2 and the requests library.
Important attributes of ContentDisposition are is_inline, filename_unsafe, filename_sanitized.
Sender
build_header builds a header value from a filename.
Security
The Content-Disposition filename should be used with caution. Do not let the sender overwrite an arbitrary filesystem location, pick arbitrary extensions or filenames with special meaning, pick filenames containing unusual or misleading characters, etc. Read RFC 6266 section 4.3 for more details.
Testing
To test in the current Python implementation:
py.test
To test compatibility across Python releases:
tox
rfc6266 is currently tested under Python 2.7, Python 2.6, Python 3.3, Python 3.2, and PyPy (1.7).
References
RFC 6266 <https://tools.ietf.org/html/rfc6266> specifies the Content-Disposition header
RFC 5987 <https://tools.ietf.org/html/rfc5987> specifies a way to encode non-ascii filenames
TC 2231 <http://greenbytes.de/tech/tc2231/> is a test suite for Content-Disposition headers
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
File details
Details for the file rfc6266-0.0.4.tar.gz
.
File metadata
- Download URL: rfc6266-0.0.4.tar.gz
- Upload date:
- Size: 8.1 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 923116bd77cf283b161a813139f5022e894e91d040686208aa33eb43db1b7703 |
|
MD5 | 772b711de0bf9fc9277fe91e7b53060c |
|
BLAKE2b-256 | b81e0f014fef1b09eb0b6dc5f10c1fcee9433cf33f53cc17ce66932e6d7babe2 |