mirror of
https://github.com/python/cpython.git
synced 2025-11-14 07:49:28 +00:00
svn+ssh://pythondev@svn.python.org/python/trunk ........ r63724 | gregory.p.smith | 2008-05-26 22:22:14 +0200 (Mon, 26 May 2008) | 6 lines Fixes issue2791: subprocess.Popen.communicate leaked a file descripton until the last reference to the Popen instance was dropped. Adding explicit close() calls fixes it. Candidate for backport to release25-maint. ........ r63726 | benjamin.peterson | 2008-05-26 22:43:24 +0200 (Mon, 26 May 2008) | 2 lines fix minor grammar typo ........ r63732 | benjamin.peterson | 2008-05-26 23:44:26 +0200 (Mon, 26 May 2008) | 2 lines remove duplication in test module ........ r63744 | lars.gustaebel | 2008-05-27 14:39:23 +0200 (Tue, 27 May 2008) | 3 lines Do not close external file objects passed to tarfile.open(mode='w:bz2') when the TarFile is closed. ........ r63754 | benjamin.peterson | 2008-05-28 03:12:35 +0200 (Wed, 28 May 2008) | 2 lines update tutorial function with more appropiate one from Eric Smith ........ r63755 | mark.hammond | 2008-05-28 03:54:55 +0200 (Wed, 28 May 2008) | 2 lines bdist_wininst now works correctly when both --skip-build and --plat-name are specified. ........ r63757 | georg.brandl | 2008-05-28 13:21:39 +0200 (Wed, 28 May 2008) | 2 lines #2989: add PyType_Modified(). ........ r63758 | benjamin.peterson | 2008-05-28 13:51:41 +0200 (Wed, 28 May 2008) | 2 lines fix spelling ........ r63760 | georg.brandl | 2008-05-28 17:41:36 +0200 (Wed, 28 May 2008) | 2 lines #2990: prevent inconsistent state while updating method cache. ........ r63775 | georg.brandl | 2008-05-29 09:18:17 +0200 (Thu, 29 May 2008) | 2 lines Two fixes in bytearray docs. ........ r63781 | georg.brandl | 2008-05-29 09:38:37 +0200 (Thu, 29 May 2008) | 2 lines #2988: add note about catching CookieError when parsing untrusted cookie data. ........ r63782 | georg.brandl | 2008-05-29 09:45:26 +0200 (Thu, 29 May 2008) | 2 lines #2985: allow i8 in XMLRPC responses. ........ r63787 | georg.brandl | 2008-05-29 16:35:39 +0200 (Thu, 29 May 2008) | 2 lines Revert #2990 patch; it's not necessary as Armin showed. ........ r63805 | raymond.hettinger | 2008-05-30 08:37:27 +0200 (Fri, 30 May 2008) | 1 line Issue 2784: fix leaks in exception exit. ........ r63806 | raymond.hettinger | 2008-05-30 08:49:47 +0200 (Fri, 30 May 2008) | 1 line Issue 2855: Fix obscure crasher by slowing down the entire module. Mimics what was done to dictionaries in r59223. ........ r63807 | raymond.hettinger | 2008-05-30 09:16:53 +0200 (Fri, 30 May 2008) | 1 line Issue 2903: Add __name__ in globals for namedtuple namespace. ........ r63808 | georg.brandl | 2008-05-30 09:54:16 +0200 (Fri, 30 May 2008) | 2 lines #2999: fix name of third parameter in unicode.replace()'s docstring. ........ r63818 | georg.brandl | 2008-05-30 21:12:13 +0200 (Fri, 30 May 2008) | 2 lines getloadavg() is not available on Windows. ........ r63819 | georg.brandl | 2008-05-30 21:17:29 +0200 (Fri, 30 May 2008) | 2 lines Better quote with single quotes. ........ r63823 | benjamin.peterson | 2008-05-30 22:44:39 +0200 (Fri, 30 May 2008) | 2 lines fix grammar ........ r63824 | marc-andre.lemburg | 2008-05-30 22:52:18 +0200 (Fri, 30 May 2008) | 5 lines Update the locale module alias table. Closes #3011. ........
233 lines
6.6 KiB
ReStructuredText
233 lines
6.6 KiB
ReStructuredText
:mod:`http.cookies` --- HTTP state management
|
|
=============================================
|
|
|
|
.. module:: http.cookies
|
|
:synopsis: Support for HTTP state management (cookies).
|
|
.. moduleauthor:: Timothy O'Malley <timo@alum.mit.edu>
|
|
.. sectionauthor:: Moshe Zadka <moshez@zadka.site.co.il>
|
|
|
|
|
|
The :mod:`http.cookies` module defines classes for abstracting the concept of
|
|
cookies, an HTTP state management mechanism. It supports both simple string-only
|
|
cookies, and provides an abstraction for having any serializable data-type as
|
|
cookie value.
|
|
|
|
The module formerly strictly applied the parsing rules described in the
|
|
:rfc:`2109` and :rfc:`2068` specifications. It has since been discovered that
|
|
MSIE 3.0x doesn't follow the character rules outlined in those specs. As a
|
|
result, the parsing rules used are a bit less strict.
|
|
|
|
.. note::
|
|
|
|
On encountering an invalid cookie, :exc:`CookieError` is raised, so if your
|
|
cookie data comes from a browser you should always prepare for invalid data
|
|
and catch :exc:`CookieError` on parsing.
|
|
|
|
|
|
.. exception:: CookieError
|
|
|
|
Exception failing because of :rfc:`2109` invalidity: incorrect attributes,
|
|
incorrect :mailheader:`Set-Cookie` header, etc.
|
|
|
|
|
|
.. class:: BaseCookie([input])
|
|
|
|
This class is a dictionary-like object whose keys are strings and whose values
|
|
are :class:`Morsel` instances. Note that upon setting a key to a value, the
|
|
value is first converted to a :class:`Morsel` containing the key and the value.
|
|
|
|
If *input* is given, it is passed to the :meth:`load` method.
|
|
|
|
|
|
.. class:: SimpleCookie([input])
|
|
|
|
This class derives from :class:`BaseCookie` and overrides :meth:`value_decode`
|
|
and :meth:`value_encode` to be the identity and :func:`str` respectively.
|
|
|
|
|
|
.. seealso::
|
|
|
|
Module :mod:`http.cookiejar`
|
|
HTTP cookie handling for web *clients*. The :mod:`http.cookiejar` and
|
|
:mod:`http.cookies` modules do not depend on each other.
|
|
|
|
:rfc:`2109` - HTTP State Management Mechanism
|
|
This is the state management specification implemented by this module.
|
|
|
|
|
|
.. _cookie-objects:
|
|
|
|
Cookie Objects
|
|
--------------
|
|
|
|
|
|
.. method:: BaseCookie.value_decode(val)
|
|
|
|
Return a decoded value from a string representation. Return value can be any
|
|
type. This method does nothing in :class:`BaseCookie` --- it exists so it can be
|
|
overridden.
|
|
|
|
|
|
.. method:: BaseCookie.value_encode(val)
|
|
|
|
Return an encoded value. *val* can be any type, but return value must be a
|
|
string. This method does nothing in :class:`BaseCookie` --- it exists so it can
|
|
be overridden
|
|
|
|
In general, it should be the case that :meth:`value_encode` and
|
|
:meth:`value_decode` are inverses on the range of *value_decode*.
|
|
|
|
|
|
.. method:: BaseCookie.output([attrs[, header[, sep]]])
|
|
|
|
Return a string representation suitable to be sent as HTTP headers. *attrs* and
|
|
*header* are sent to each :class:`Morsel`'s :meth:`output` method. *sep* is used
|
|
to join the headers together, and is by default the combination ``'\r\n'``
|
|
(CRLF).
|
|
|
|
|
|
.. method:: BaseCookie.js_output([attrs])
|
|
|
|
Return an embeddable JavaScript snippet, which, if run on a browser which
|
|
supports JavaScript, will act the same as if the HTTP headers was sent.
|
|
|
|
The meaning for *attrs* is the same as in :meth:`output`.
|
|
|
|
|
|
.. method:: BaseCookie.load(rawdata)
|
|
|
|
If *rawdata* is a string, parse it as an ``HTTP_COOKIE`` and add the values
|
|
found there as :class:`Morsel`\ s. If it is a dictionary, it is equivalent to::
|
|
|
|
for k, v in rawdata.items():
|
|
cookie[k] = v
|
|
|
|
|
|
.. _morsel-objects:
|
|
|
|
Morsel Objects
|
|
--------------
|
|
|
|
|
|
.. class:: Morsel()
|
|
|
|
Abstract a key/value pair, which has some :rfc:`2109` attributes.
|
|
|
|
Morsels are dictionary-like objects, whose set of keys is constant --- the valid
|
|
:rfc:`2109` attributes, which are
|
|
|
|
* ``expires``
|
|
* ``path``
|
|
* ``comment``
|
|
* ``domain``
|
|
* ``max-age``
|
|
* ``secure``
|
|
* ``version``
|
|
|
|
The keys are case-insensitive.
|
|
|
|
|
|
.. attribute:: Morsel.value
|
|
|
|
The value of the cookie.
|
|
|
|
|
|
.. attribute:: Morsel.coded_value
|
|
|
|
The encoded value of the cookie --- this is what should be sent.
|
|
|
|
|
|
.. attribute:: Morsel.key
|
|
|
|
The name of the cookie.
|
|
|
|
|
|
.. method:: Morsel.set(key, value, coded_value)
|
|
|
|
Set the *key*, *value* and *coded_value* members.
|
|
|
|
|
|
.. method:: Morsel.isReservedKey(K)
|
|
|
|
Whether *K* is a member of the set of keys of a :class:`Morsel`.
|
|
|
|
|
|
.. method:: Morsel.output([attrs[, header]])
|
|
|
|
Return a string representation of the Morsel, suitable to be sent as an HTTP
|
|
header. By default, all the attributes are included, unless *attrs* is given, in
|
|
which case it should be a list of attributes to use. *header* is by default
|
|
``"Set-Cookie:"``.
|
|
|
|
|
|
.. method:: Morsel.js_output([attrs])
|
|
|
|
Return an embeddable JavaScript snippet, which, if run on a browser which
|
|
supports JavaScript, will act the same as if the HTTP header was sent.
|
|
|
|
The meaning for *attrs* is the same as in :meth:`output`.
|
|
|
|
|
|
.. method:: Morsel.OutputString([attrs])
|
|
|
|
Return a string representing the Morsel, without any surrounding HTTP or
|
|
JavaScript.
|
|
|
|
The meaning for *attrs* is the same as in :meth:`output`.
|
|
|
|
|
|
.. _cookie-example:
|
|
|
|
Example
|
|
-------
|
|
|
|
The following example demonstrates how to use the :mod:`http.cookies` module.
|
|
|
|
.. doctest::
|
|
:options: +NORMALIZE_WHITESPACE
|
|
|
|
>>> from http import cookies
|
|
>>> C = cookies.SimpleCookie()
|
|
>>> C["fig"] = "newton"
|
|
>>> C["sugar"] = "wafer"
|
|
>>> print(C) # generate HTTP headers
|
|
Set-Cookie: fig=newton
|
|
Set-Cookie: sugar=wafer
|
|
>>> print(C.output()) # same thing
|
|
Set-Cookie: fig=newton
|
|
Set-Cookie: sugar=wafer
|
|
>>> C = cookies.SimpleCookie()
|
|
>>> C["rocky"] = "road"
|
|
>>> C["rocky"]["path"] = "/cookie"
|
|
>>> print(C.output(header="Cookie:"))
|
|
Cookie: rocky=road; Path=/cookie
|
|
>>> print(C.output(attrs=[], header="Cookie:"))
|
|
Cookie: rocky=road
|
|
>>> C = cookies.SimpleCookie()
|
|
>>> C.load("chips=ahoy; vienna=finger") # load from a string (HTTP header)
|
|
>>> print(C)
|
|
Set-Cookie: chips=ahoy
|
|
Set-Cookie: vienna=finger
|
|
>>> C = cookies.SimpleCookie()
|
|
>>> C.load('keebler="E=everybody; L=\\"Loves\\"; fudge=\\012;";')
|
|
>>> print(C)
|
|
Set-Cookie: keebler="E=everybody; L=\"Loves\"; fudge=\012;"
|
|
>>> C = cookies.SimpleCookie()
|
|
>>> C["oreo"] = "doublestuff"
|
|
>>> C["oreo"]["path"] = "/"
|
|
>>> print(C)
|
|
Set-Cookie: oreo=doublestuff; Path=/
|
|
>>> C = cookies.SimpleCookie()
|
|
>>> C["twix"] = "none for you"
|
|
>>> C["twix"].value
|
|
'none for you'
|
|
>>> C = cookies.SimpleCookie()
|
|
>>> C["number"] = 7 # equivalent to C["number"] = str(7)
|
|
>>> C["string"] = "seven"
|
|
>>> C["number"].value
|
|
'7'
|
|
>>> C["string"].value
|
|
'seven'
|
|
>>> print(C)
|
|
Set-Cookie: number=7
|
|
Set-Cookie: string=seven
|