http.cookies
— HTTP state management¶
Source code: Lib/http/cookies.py
El módulo http.cookies
define clases para abstraer el concepto de cookies, un mecanismo de gestión de estado HTTP. Admite cookies simples de solo cadenas de caracteres y proporciona una abstracción para tener cualquier tipo de datos serializable como valor de cookie.
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 didn’t follow the character rules outlined in those specs; many current-day browsers and servers have also relaxed parsing rules when it comes to cookie handling. As a result, this module now uses parsing rules that are a bit less strict than they once were.
The character set, string.ascii_letters
, string.digits
and
!#$%&'*+-.^_`|~:
denote the set of valid characters allowed by this module
in a cookie name (as key
).
Distinto en la versión 3.3: Allowed “:” as a valid cookie name character.
Nota
Al encontrar una cookie no válida, se lanza CookieError
, por lo que si los datos de su cookie provienen de un navegador, siempre debe prepararse para los datos no válidos y detectar CookieError
en el análisis.
- exception http.cookies.CookieError¶
Error de excepción debido a la invalidez de RFC 2109: atributos incorrectos, encabezado Set-Cookie incorrecto, etc.
- class http.cookies.BaseCookie([input])¶
Esta clase es un objeto similar a un diccionario cuyas claves son cadenas de caracteres y cuyos valores son
Morsel
. Tenga en cuenta que al establecer una clave en un valor, el valor se convierte primero enMorsel
que contiene la clave y el valor.Si se proporciona input, se pasa al método
load()
.
- class http.cookies.SimpleCookie([input])¶
This class derives from
BaseCookie
and overridesvalue_decode()
andvalue_encode()
.SimpleCookie
supports strings as cookie values. When setting the value,SimpleCookie
calls the builtinstr()
to convert the value to a string. Values received from HTTP are kept as strings.
Ver también
- Módulo
http.cookiejar
Manejo de cookies HTTP para web clients. Los módulos
http.cookiejar
andhttp.cookies
no dependen el uno del otro.- RFC 2109 - Mecanismo de gestión de estado HTTP
Esta es la especificación de gestión de estado implementada por este módulo.
Objetos de cookie¶
- BaseCookie.value_decode(val)¶
Retorna una tupla
(real_value, coded_value)
de una representación de cadena de caracteres.real_value
puede ser de cualquier tipo. Este método no decodifica enBaseCookie
— existe por lo que puede ser anulado.
- BaseCookie.value_encode(val)¶
Retorna una tupla
(real_value, coded_value)
. val puede ser de cualquier tipo, perocoded_value
siempre se convertirá en una cadena de caracteres. Este método no codifica enBaseCookie
— existe por lo que se puede anular.En general, debería darse el caso de que
value_encode()
yvalue_decode()
sean inversas en el rango de value_decode.
- BaseCookie.output(attrs=None, header='Set-Cookie:', sep='\r\n')¶
Return a string representation suitable to be sent as HTTP headers. attrs and header are sent to each
Morsel
’soutput()
method. sep is used to join the headers together, and is by default the combination'\r\n'
(CRLF).
Objetos Morsel¶
- class http.cookies.Morsel¶
Resumen de un par clave/valor, que tiene algunos atributos RFC 2109.
Morsels are dictionary-like objects, whose set of keys is constant — the valid RFC 2109 attributes, which are:
El atributo
httponly
especifica que la cookie solo se transfiere en solicitudes HTTP y no es accesible a través de JavaScript. Esto tiene como objetivo mitigar algunas formas de secuencias de comandos entre sitios.El atributo
samesite
especifica que el navegador no puede enviar la cookie junto con solicitudes entre sitios. Esto ayuda a mitigar los ataques CSRF. Los valores válidos para este atributo son «Strict» y «Lax».Las claves no distinguen entre mayúsculas y minúsculas y su valor predeterminado es
''
.Distinto en la versión 3.7: Los atributos
key
,value
ycoded_value
son de solo lectura. Utiliceset()
para configurarlos.Distinto en la versión 3.8: Se agregó soporte para el atributo
samesite
.
- Morsel.value¶
El valor de la cookie.
- Morsel.coded_value¶
El valor codificado de la cookie — esto es lo que se debe enviar.
- Morsel.key¶
El nombre de la cookie.
- Morsel.set(key, value, coded_value)¶
Establezca los atributos key, value y coded_value.
- Morsel.output(attrs=None, header='Set-Cookie:')¶
Retorna una representación de cadena de caracteres del Morsel, adecuada para enviarse como un encabezado HTTP. De forma predeterminada, se incluyen todos los atributos, a menos que se proporcione attrs, en cuyo caso debería ser una lista de atributos a utilizar. header es por defecto
"Set-Cookie:"
.
- Morsel.js_output(attrs=None)¶
Retorna un fragmento de código JavaScript que, si se ejecuta en un navegador que admita JavaScript, actuará de la misma forma que si se hubiera enviado el encabezado HTTP.
El significado de attrs es el mismo que en
output()
.
- Morsel.OutputString(attrs=None)¶
Retorna una cadena de caracteres que representa el Morsel, sin ningún HTTP o JavaScript circundante.
El significado de attrs es el mismo que en
output()
.
- Morsel.update(values)¶
Actualice los valores en el diccionario Morsel con los valores en el diccionario values. Lanza un error si alguna de las claves en el values dict no es un atributo válido RFC 2109.
Distinto en la versión 3.5: se lanza un error para claves no válidas.
- Morsel.copy(value)¶
Retorna una copia superficial del objeto Morsel.
Distinto en la versión 3.5: retorna un objeto Morsel en lugar de un dict.
- Morsel.setdefault(key, value=None)¶
Lanza un error si la clave no es un atributo válido RFC 2109; de lo contrario, se comporta igual que
dict.setdefault()
.
Ejemplo¶
El siguiente ejemplo demuestra cómo utilizar el módulo http.cookies
.
>>> 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