http.server — HTTP 伺服器¶
此模組定義了用於實作 HTTP 伺服器的類別。
警告
http.server is not recommended for production. It only implements
basic security checks.
可用性: not WASI.
此模組在 WebAssembly 平台上不起作用或無法使用。更多資訊請參閱 WebAssembly 平台。
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.在 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
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.在 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.在 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.BaseHTTPRequestHandler有以下實例變數:- 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.
在 3.6 版的變更: This is an
io.BufferedIOBasestream.
BaseHTTPRequestHandler擁有以下屬性:- 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
send_error()method for building an error response to the client. The string is filled by default with variables fromresponsesbased on the status code that passed tosend_error().
- error_content_type¶
Specifies the Content-Type HTTP header of error responses sent to the client. The default value is
'text/html'.
- protocol_version¶
Specifies the HTTP version to which the server is conformant. It is sent in responses to let the client know the server's communication capabilities for future requests. If set to
'HTTP/1.1', the server will permit HTTP persistent connections; however, your server must then include an accurateContent-Lengthheader (usingsend_header()) in all of its responses to clients. For backwards compatibility, the setting defaults to'HTTP/1.0'.
- MessageClass¶
Specifies an
email.message.Message-like class to parse HTTP headers. Typically, this is not overridden, and it defaults tohttp.client.HTTPMessage.
- responses¶
This attribute contains a mapping of error code integers to two-element tuples containing a short and long message. For example,
{code: (shortmessage, longmessage)}. The shortmessage is usually used as the message key in an error response, and longmessage as the explain key. It is used bysend_response_only()andsend_error()methods.
BaseHTTPRequestHandler實例擁有以下方法:- 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()¶
When an HTTP/1.1 conformant server receives an
Expect: 100-continuerequest header it responds back with a100 Continuefollowed by200 OKheaders. This method can be overridden to raise an error if the server does not want the client to continue. For example, the server can choose to send417 Expectation Failedas a response header andreturn False.在 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_formatattribute and emitted, after a complete set of headers, as the response body. Theresponsesattribute 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.在 3.4 版的變更: The error response includes a Content-Length header. Added the explain argument.
- send_response(code, message=None)¶
Adds a response header to the headers buffer and logs the accepted request. The HTTP response line is written to the internal buffer, followed by Server and Date headers. The values for these two headers are picked up from the
version_string()anddate_time_string()methods, respectively. If the server does not intend to send any other headers using thesend_header()method, thensend_response()should be followed by anend_headers()call.在 3.3 版的變更: Headers are stored to an internal buffer and
end_headers()needs to be called explicitly.
- send_header(keyword, value)¶
Adds the HTTP header to an internal buffer which will be written to the output stream when either
end_headers()orflush_headers()is invoked. keyword should specify the header keyword, with value specifying its value. Note that, after the send_header calls are done,end_headers()MUST BE called in order to complete the operation.This method does not reject input containing CRLF sequences.
在 3.2 版的變更: Headers are stored in an internal buffer.
- send_response_only(code, message=None)¶
Sends the response header only, used for the purposes when
100 Continueresponse is sent by the server to the client. The headers not buffered and sent directly the output stream.If the message is not specified, the HTTP message corresponding the response code is sent.This method does not reject message containing CRLF sequences.
在 3.2 版被加入.
- end_headers()¶
Adds a blank line (indicating the end of the HTTP headers in the response) to the headers buffer and calls
flush_headers().在 3.2 版的變更: The buffered headers are written to the output stream.
- flush_headers()¶
Finally send the headers to the output stream and flush the internal headers buffer.