http.server
— Servidores HTTP¶
Código fuente: Lib/http/server.py
Este módulo define clases para implementar servidores HTTP.
Advertencia
http.server
no se recomienda para producción. Sólo implementa controles de seguridad básicos.
Availability: not Emscripten, not WASI.
Este módulo no funciona o no está disponible en las plataformas WebAssembly wasm32-emscripten
y wasm32-wasi
. Consulte Plataformas WebAssembly para obtener más información.
Una clase, HTTPServer
, es una subclase socketserver.TCPServer
. Crea y escucha en el socket HTTP, enviando las peticiones a un handler. El código para crear y ejecutar el servidor se ve así:
def run(server_class=HTTPServer, handler_class=BaseHTTPRequestHandler):
server_address = ('', 8000)
httpd = server_class(server_address, handler_class)
httpd.serve_forever()
- class http.server.HTTPServer(server_address, RequestHandlerClass)¶
Esta clase se basa en la clase
TCPServer
almacenando la dirección del servidor como variables de instancia llamadasnombre_del_servidor
ypuerto_del_servidor
. El servidor es accesible por el handler, típicamente a través de la variable de instanciaservidor
del handler.
- class http.server.ThreadingHTTPServer(server_address, RequestHandlerClass)¶
Esta clase es idéntica a HTTPServer, pero utiliza subprocesos para controlar las solicitudes mediante el uso de
ThreadingMixIn
. Esto es útil para controlar los sockets de pre-apertura de los navegadores web, en los queHTTPServer
esperaría indefinidamente.Nuevo en la versión 3.7.
El HTTPServer
y ThreadingHTTPServer
deben recibir un RequestHandlerClass en la creación de instancias, de los cuales este módulo proporciona tres variantes diferentes:
- class http.server.BaseHTTPRequestHandler(request, client_address, server)¶
Esta clase se utiliza para controlar las solicitudes HTTP que llegan al servidor. Por sí mismo, no puede responder a ninguna solicitud HTTP real; debe ser subclase para manejar cada método de solicitud (por ejemplo, GET o POST).
BaseHTTPRequestHandler
proporciona una serie de variables de clase e instancia, y métodos para su uso por subclases.The handler will parse the request and the headers, then call a method specific to the request type. The method name is constructed from the request. For example, for the request method
SPAM
, thedo_SPAM()
method will be called with no arguments. All of the relevant information is stored in instance variables of the handler. Subclasses should not need to override or extend the__init__()
method.BaseHTTPRequestHandler
tiene las siguientes variables de instancia:- client_address¶
Contiene una tupla con el formato
(host, port)
que hace referencia a la dirección del cliente.
- server¶
Contiene la instancia del servidor.
- close_connection¶
Booleano que se debe establecer antes de
handle_one_request()
retorna, que indica si se puede esperar otra solicitud o si la conexión debe cerrarse.
- requestline¶
Contiene la representación de cadena de la línea de solicitud HTTP. Se elimina el CRLF de terminación. Este atributo debe establecerse mediante
handle_one_request()
. Si no se ha procesado ninguna línea de solicitud válida, debe establecerse en la cadena vacía.
- command¶
Contiene el comando (tipo de petición). Por ejemplo,
'GET'
.
- path¶
Contiene la ruta de la solicitud. Si el componente de consulta de la URL está presente,
path
incluye la consulta. Usando la terminología de: rfc: 3986,path
aquí incluyehier-part
yquery
.
- request_version¶
Contiene la versión de la cadena de caracteres para la petición. Por ejemplo,
HTTP/1.0'
.
- headers¶
Contiene una instancia de la clase especificada por la variable de clase
MessageClass
. Esta instancia analiza y gestiona las cabeceras de la petición HTTP. La funciónparse_headers()
dehttp.client
se usa para parsear las cabeceras y requiere que la petición HTTP proporcione una cabecera válida de estilo RFC 2822.
- rfile¶
Un flujo de entrada
io.BufferedIOBase
, listo para leer desde el inicio de los datos de entrada opcionales.
- wfile¶
Contiene el flujo de salida para escribir una respuesta al cliente. Se debe utilizar la adherencia apropiada al protocolo HTTP cuando se escribe en este flujo para lograr una interoperación exitosa con los clientes HTTP.
Distinto en la versión 3.6: Este es un flujo de
io.BufferedIOBase
.
BaseHTTPRequestHandler
tiene los siguientes atributos:- server_version¶
Especifica la versión del software del servidor. Es posible que desee anular esto. El formato es de múltiples cadenas separadas por espacio en blanco, donde cada cadena es de la forma nombre[/versión]. Por ejemplo,
BaseHTTP/0.2'
.
- sys_version¶
Contiene la versión del sistema Python, en una forma utilizable por el método
version_string
y la variable de claseserver_version
. Por ejemplo,Python/1.4'
.
- error_message_format¶
Especifica una cadena de formato que debe ser usada por el método
send_error()
para construir una respuesta de error al cliente. La cadena se rellena por defecto con variables deresponses
basadas en el código de estado que pasó asend_error()
.
- error_content_type¶
Especifica el encabezado HTTP Content-Type de las respuestas de error enviadas al cliente. El valor predeterminado es
'text/html'
.
- protocol_version¶
Especifica la versión de HTTP con la cual el servidor es conforme. Es enviada como respuesta para informarle al cliente sobre las capacidades de comunicación del servidor para siguientes peticiones. Si se establece en
'HTTP/1.1'
, el servidor permitirá conexiones persistentes HTTP; sin embargo, el servidor debe incluir un encabezado exactoContent-Length
(usandosend_header()
) en todas sus respuestas a los clientes. Para la compatibilidad con versiones anteriores, el valor predeterminado es'HTTP/1.0'
.
- MessageClass¶
Especifica una
email.message.Message
-como clase para analizar los encabezados HTTP. Típicamente, esto no es anulado, y por defecto eshttp.client.HTTPMessage
.
- responses¶
Este atributo contiene una asignación de enteros de código de error a tuplas de dos elementos que contienen un mensaje corto y largo. Por ejemplo,
{code (shortmessage, longmessage)}
. El shortmessage se utiliza normalmente como la clave message en una respuesta de error, y longmessage como la clave explain. Es utilizado porsend_response_only()
ysend_error()
métodos.
Una instancia
BaseHTTPRequestHandler
tiene los siguientes métodos:- handle()¶
Calls
handle_one_request()
once (or, if persistent connections are enabled, multiple times) to handle incoming HTTP requests. You should never need to override it; instead, implement appropriatedo_*()
methods.
- handle_one_request()¶
This method will parse and dispatch the request to the appropriate
do_*()
method. You should never need to override it.
- handle_expect_100()¶
Cuando un servidor compatible con HTTP/1.1 recibe un encabezado de solicitud
Expect: 100-continue
, responde con un100 Continue
seguido de encabezados200 OK
. Este método se puede anular para generar un error si el servidor no desea que el cliente continúe. Por ejemplo, el servidor puede optar por enviar417 Expectation Failed
como encabezado de respuesta yreturn False
.Nuevo en la versión 3.2.
- send_error(code, message=None, explain=None)¶
Sends and logs a complete error reply to the client. The numeric code specifies the HTTP error code, with message as an optional, short, human readable description of the error. The explain argument can be used to provide more detailed information about the error; it will be formatted using the
error_message_format
attribute and emitted, after a complete set of headers, as the response body. Theresponses
attribute holds the default values for message and explain that will be used if no value is provided; for unknown codes the default value for both is the string???
. The body will be empty if the method is HEAD or the response code is one of the following:1xx
,204 No Content
,205 Reset Content
,304 Not Modified
.Distinto en la versión 3.4: La respuesta de error incluye un encabezado de longitud de contenido. Añadido el argumento explain.
- send_response(code, message=None)¶
Agrega un encabezado de respuesta al búfer de encabezados y registra la solicitud aceptada. La línea de respuesta HTTP se escribe en el búfer interno, seguido de los encabezados Server y Date. Los valores de estos dos encabezados se recogen de los métodos
version_string()
ydate_time_string()
, respectivamente. Si el servidor no tiene la intención de enviar ningún otro encabezado utilizando el métodosend_header()
, entoncessend_response()
debe ir seguido de una llamadaend_headers()
.Distinto en la versión 3.3: Los encabezados se almacenan en un búfer interno y
end_headers()
debe llamarse explícitamente.
- send_header(keyword, value)¶
Agrega el encabezado HTTP a un búfer interno que se escribirá en la secuencia de salida cuando se invoca
end_headers()
oflush_headers()
. keyword debe especificar la palabra clave header, con value especificando su valor. Tenga en cuenta que, después de que se realizan las llamadas send_header,end_headers()
DEBE llamarse para completar la operación.Distinto en la versión 3.2: Los encabezados se almacenan en un búfer interno.
- send_response_only(code, message=None)¶
Envía el encabezado de respuesta solamente, usado para los propósitos cuando la respuesta
100 Continue
es enviada por el servidor al cliente. Los encabezados no se almacenan en el buffer y envían directamente el flujo de salida. Si no se especifica el message, se envía el mensaje HTTP correspondiente al code de respuesta.Nuevo en la versión 3.2.
- end_headers()¶
Añade una línea en blanco (indicando el final de las cabeceras HTTP en la respuesta) al buffer de cabeceras y llama a
flush_headers()
.Distinto en la versión 3.2: Los encabezados del buffer se escriben en el flujo de salida.
- flush_headers()¶
Finalmente envía los encabezados al flujo de salida y limpia el buffer interno de los cabezales.
Nuevo en la versión 3.3.
- log_request(code='-', size='-')¶
Registra una solicitud aceptada (exitosa). El code debe especificar el código numérico HTTP asociado a la respuesta. Si un tamaño de la respuesta está disponible, entonces debe ser pasado como el parámetro size.
- log_error(...)¶
Registra un error cuando una solicitud no puede ser cumplida. Por defecto, pasa el mensaje a
log_message()
, por lo que toma los mismos argumentos (format y valores adicionales).
- log_message(format, ...)¶
Registra un mensaje arbitrario en
sys.stderr
. Normalmente se anula para crear mecanismos personalizados de registro de errores. El argumento format es una cadena de formato estándar de estilo de impresión, donde los argumentos adicionales alog_message()
se aplican como entradas al formato. La dirección ip del cliente y la fecha y hora actual son prefijadas a cada mensaje registrado.
- version_string()¶
Retorna la cadena de versiones del software del servidor. Esta es una combinación de los atributos
server_version
ysys_version
.
- date_time_string(timestamp=None)¶
Retorna la fecha y la hora dadas por timestamp (que debe ser
None
o en el formato retornado portime.time`()
), formateado para un encabezado de mensaje. Si se omite timestamp, utiliza la fecha y la hora actuales.El resultado se muestra como
Sun, 06 Nov 1994 08:49:37 GMT'
.
- log_date_time_string()¶
Retorna la fecha y la hora actuales, formateadas para el registro.
- address_string()¶
Retorna la dirección del cliente.
Distinto en la versión 3.3: Anteriormente, se realizó una búsqueda de nombres. Para evitar retrasos en la resolución del nombre, ahora siempre retorna la dirección IP.
- class http.server.SimpleHTTPRequestHandler(request, client_address, server, directory=None)¶
Esta clase sirve archivos del directorio directory e inferior, o del directorio actual si no se proporciona directory, mapeando directamente la estructura del directorio a las solicitudes HTTP.
Distinto en la versión 3.7: Added the directory parameter.
Distinto en la versión 3.9: El parámetro directory acepta un path-like object.
La carga de trabajo, como el análisis de la solicitud, lo hace la clase base
BaseHTTPRequestHandler
. Esta clase implementa las funcionesdo_GET()
ydo_HEAD()
.Los siguientes se definen como atributos de clase de
SimpleHTTPRequestHandler
:- server_version¶
Esto sería
"SimpleHTTP/" + __version__
, donde__version__
se define a nivel de módulo.
- extensions_map¶
Un diccionario que asigna sufijos a tipos MIME contiene sobreescrituras personalizadas para las asignaciones predeterminadas del sistema. El mapeo se usa sin distinción entre mayúsculas y minúsculas, por lo que solo debe contener claves en minúsculas.
Distinto en la versión 3.9: Este diccionario ya no contiene las asignaciones predeterminadas del sistema, sino que solo contiene anulaciones.
Una instancia
SimpleHTTPRequestHandler
tiene los siguientes métodos:- do_HEAD()¶
Este método sirve para el tipo de petición:
'HEAD'
envía los encabezados que enviaría para la petición equivalenteGET
. Ver el métododo_GET()
para una explicación más completa de los posibles encabezados.
- do_GET()¶
La solicitud se asigna a un archivo local interpretando la solicitud como una ruta relativa al directorio de trabajo actual.
Si la solicitud fue mapeada a un directorio, el directorio se comprueba para un archivo llamado
index.html
orindex.htm
(en ese orden). Si se encuentra, se retorna el contenido del archivo; de lo contrario, se genera un listado del directorio llamando al métodolist_directory()
. Este método utilizaos.listdir()
para escanear el directorio, y retorna una respuesta de error404
si falla ellistdir()
.Si la solicitud fue asignada a un archivo, se abre. Cualquier excepción
OSError
al abrir el archivo solicitado se asigna a un error404
,'File not found'
. Si había un encabezado'If-Modified-Since'
en la solicitud, y el archivo no fue modificado después de este tiempo, se envía una respuesta304
,'Not Modified'
. De lo contrario, el tipo de contenido se adivina llamando al métodoguess_type()
, que a su vez utiliza la variable extensions_map, y se retorna el contenido del archivo.Un encabezado de
'Content-type:'
con el tipo de contenido adivinado, seguido de un encabezado de'Content-Length:'
con el tamaño del archivo y un encabezado de'Last-Modified:'
con el tiempo de modificación del archivo.Luego sigue una línea en blanco que significa el final de los encabezados, y luego se imprime el contenido del archivo. Si el tipo MIME del archivo comienza con
text/
el archivo se abre en modo de texto; en caso contrario se utiliza el modo binario.Por ejemplo, ver la implementación de la función
test
en Lib/http/server.py.Distinto en la versión 3.7: Soporta la cabecera
'If-Modified-Since'
.
La clase SimpleHTTPRequestHandler
puede ser usada de la siguiente manera para crear un servidor web muy básico que sirva archivos relativos al directorio actual:
import http.server
import socketserver
PORT = 8000
Handler = http.server.SimpleHTTPRequestHandler
with socketserver.TCPServer(("", PORT), Handler) as httpd:
print("serving at port", PORT)
httpd.serve_forever()
http.server
también puede ser invocado directamente usando la opción -m
del intérprete. Como en el ejemplo anterior, esto sirve a los archivos relativos al directorio actual:
python -m http.server
Por defecto, el servidor escucha en el puerto 8000. El valor predeterminado se puede anular pasando el número de puerto deseado como argumento:
python -m http.server 9000
Por defecto, el servidor se vincula a todas las interfaces. La opción -b/--bind
especifica una dirección específica a la que se vinculará. Tanto las direcciones IPv4 como las IPv6 están soportadas. Por ejemplo, el siguiente comando hace que el servidor se vincule sólo al localhost:
python -m http.server --bind 127.0.0.1
Distinto en la versión 3.4: Added the --bind
option.
Distinto en la versión 3.8: Support IPv6 in the --bind
option.
Por defecto, el servidor utiliza el directorio actual. La opción -d/--directory
especifica un directorio al que debe servir los archivos. Por ejemplo, el siguiente comando utiliza un directorio específico:
python -m http.server --directory /tmp/
Distinto en la versión 3.7: Added the --directory
option.
Por defecto, el servidor es conforme con HTTP/1.0. La opción -p/--protocol
especifica la versión HTTP con la que cumple el servidor. Por ejemplo, el siguiente comando ejecuta un servidor conforme con HTTP/1.1:
python -m http.server --protocol HTTP/1.1
Distinto en la versión 3.11: Added the --protocol
option.
- class http.server.CGIHTTPRequestHandler(request, client_address, server)¶
Esta clase se utiliza para servir tanto a los archivos como a la salida de los scripts CGI del directorio actual y del siguiente. Note que el mapeo de la estructura jerárquica de HTTP a la estructura del directorio local es exactamente como en
SimpleHTTPRequestHandler
.Nota
Los scripts CGI ejecutados por la clase
CGIHTTPRequestHandler
no pueden ejecutar redirecciones (código HTTP 302), porque el código 200 (la salida del script sigue) se envía antes de la ejecución del script CGI. Esto adelanta el código de estado.La clase, sin embargo, ejecutará el script CGI, en lugar de servirlo como un archivo, si adivina que es un script CGI. Sólo se usan CGI basados en directorios — la otra configuración común del servidor es tratar las extensiones especiales como denotando los scripts CGI.
Las funciones
do_GET()
ydo_HEAD()
se modifican para ejecutar scripts CGI y servir la salida, en lugar de servir archivos, si la petición lleva a algún lugar por debajo de la rutacgi_directories
.La
CGIHTTPRequestHandler
define el siguiente miembro de datos:- cgi_directories¶
Esto por defecto es
['/cgi-bin', '/htbin']
y describe los directorios a tratar como si contuvieran scripts CGI.
La
CGIHTTPRequestHandler
define el siguiente método:- do_POST()¶
Este método sirve para el tipo de petición
'POST'
, sólo permitido para scripts CGI. El error 501, «Can only POST to CGI scripts», se produce cuando se intenta enviar a una url no CGI.
Tenga en cuenta que los scripts CGI se ejecutarán con UID de usuario nobody, por razones de seguridad. Los problemas con el script CGI serán traducidos al error 403.
CGIHTTPRequestHandler
puede ser activado en la línea de comandos pasando la opción --cgi
:
python -m http.server --cgi
Advertencia
CGIHTTPRequestHandler
and the --cgi
command line option
are not intended for use by untrusted clients and may be vulnerable
to exploitation. Always use within a secure environment.
Consideraciones de seguridad¶
SimpleHTTPRequestHandler
seguirá los enlaces simbólicos cuando gestione peticiones, esto hace posible que se sirvan ficheros fuera del directorio especificado.
Earlier versions of Python did not scrub control characters from the
log messages emitted to stderr from python -m http.server
or the
default BaseHTTPRequestHandler
.log_message
implementation. This could allow remote clients connecting to your
server to send nefarious control codes to your terminal.
Distinto en la versión 3.11.1: Control characters are scrubbed in stderr logs.