http.server — HTTP servers¶
Source code: Lib/http/server.py
This module defines classes for implementing HTTP servers.
Warning
http.server is not recommended for production. It only implements
basic security checks.
Availability: not WASI.
This module does not work or is not available on WebAssembly. See WebAssembly platforms for more information.
One class, HTTPServer, is a socketserver.TCPServer subclass.
It creates and listens at the HTTP socket, dispatching the requests to a
handler. Code to create and run the server looks like this:
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)¶
This class builds on the
TCPServerclass by storing the server address as instance variables namedserver_nameandserver_port. The server is accessible by the handler, typically through the handler’sserverinstance variable.
- class http.server.ThreadingHTTPServer(server_address, RequestHandlerClass)¶
This class is identical to HTTPServer but uses threads to handle requests by using the
ThreadingMixIn. This is useful to handle web browsers pre-opening sockets, on whichHTTPServerwould wait indefinitely.Added in version 3.7.
- class http.server.HTTPSServer(server_address, RequestHandlerClass, bind_and_activate=True, *, certfile, keyfile=None, password=None, alpn_protocols=None)¶
Subclass of
HTTPServerwith a wrapped socket using thesslmodule. If thesslmodule is not available, instantiating aHTTPSServerobject fails with aRuntimeError.The certfile argument is the path to the SSL certificate chain file, and the keyfile is the path to file containing the private key.
A password can be specified for files protected and wrapped with PKCS#8, but beware that this could possibly expose hardcoded passwords in clear.
See also
See
ssl.SSLContext.load_cert_chain()for additional information on the accepted values for certfile, keyfile and password.When specified, the alpn_protocols argument must be a sequence of strings specifying the “Application-Layer Protocol Negotiation” (ALPN) protocols supported by the server. ALPN allows the server and the client to negotiate the application protocol during the TLS handshake.
By default, it is set to
["http/1.1"], meaning the server supports HTTP/1.1.Added in version 3.14.
- class http.server.ThreadingHTTPSServer(server_address, RequestHandlerClass, bind_and_activate=True, *, certfile, keyfile=None, password=None, alpn_protocols=None)¶
This class is identical to
HTTPSServerbut uses threads to handle requests by inheriting fromThreadingMixIn. This is analogous toThreadingHTTPServeronly usingHTTPSServer.Added in version 3.14.
The HTTPServer, ThreadingHTTPServer, HTTPSServer and
ThreadingHTTPSServer must be given a RequestHandlerClass on
instantiation, of which this module provides three different variants:
- class http.server.BaseHTTPRequestHandler(request, client_address, server)¶
This class is used to handle the HTTP requests that arrive at the server. By itself, it cannot respond to any actual HTTP requests; it must be subclassed to handle each request method (for example,
'GET'or'POST').BaseHTTPRequestHandlerprovides a number of class and instance variables, and methods for use by subclasses.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.BaseHTTPRequestHandlerhas the following instance variables:- client_address¶
Contains a tuple of the form
(host, port)referring to the client’s address.
- server¶
Contains the server instance.
- close_connection¶
Boolean that should be set before
handle_one_request()returns, indicating if another request may be expected, or if the connection should be shut down.
- requestline¶
Contains the string representation of the HTTP request line. The terminating CRLF is stripped. This attribute should be set by
handle_one_request(). If no valid request line was processed, it should be set to the empty string.
- command¶
Contains the command (request type). For example,
'GET'.
- path¶
Contains the request path. If query component of the URL is present, then
pathincludes the query. Using the terminology of RFC 3986,pathhere includeshier-partand thequery.
- request_version¶
Contains the version string from the request. For example,
'HTTP/1.0'.
- headers¶
Holds an instance of the class specified by the
MessageClassclass variable. This instance parses and manages the headers in the HTTP request. Theparse_headers()function fromhttp.clientis used to parse the headers and it requires that the HTTP request provide a valid RFC 5322 style header.
- rfile¶
An
io.BufferedIOBaseinput stream, ready to read from the start of the optional input data.
- wfile¶
Contains the output stream for writing a response back to the client. Proper adherence to the HTTP protocol must be used when writing to this stream in order to achieve successful interoperation with HTTP clients.
Changed in version 3.6: This is an
io.BufferedIOBasestream.
BaseHTTPRequestHandlerhas the following attributes:- server_version¶
Specifies the server software version. You may want to override this. The format is multiple whitespace-separated strings, where each string is of the form name[/version]. For example,
'BaseHTTP/0.2'.
- sys_version¶
Contains the Python system version, in a form usable by the
version_stringmethod and theserver_versionclass variable. For example,'Python/1.4'.
- error_message_format¶
Specifies a format string that should be used by