tornado.web provides a simple web framework with asynchronous features that allow it to scale to large numbers of open connections, making it ideal for long polling.
Here is a simple “Hello, world” example app:
import asyncio import tornado class MainHandler(tornado.web.RequestHandler): def get(self): self.write("Hello, world") async def main(): application = tornado.web.Application([ (r"/", MainHandler), ]) application.listen(8888) await asyncio.Event().wait() if __name__ == "__main__": asyncio.run(main())
See the User’s guide for additional information.
In general, methods on RequestHandler and elsewhere in Tornado are not thread-safe. In particular, methods such as write() , finish() , and flush() must only be called from the main thread. If you use multiple threads it is important to use IOLoop.add_callback to transfer control back to the main thread before finishing the request, or to limit your use of other threads to IOLoop.run_in_executor and ensure that your callbacks running in the executor do not refer to Tornado objects.
Base class for HTTP request handlers.
Subclasses must define at least one of the methods defined in the “Entry points” section below.
Applications should not construct RequestHandler objects directly and subclasses should not override __init__ (override initialize instead).
Hook for subclass initialization. Called for each request.
A dictionary passed as the third argument of a URLSpec will be supplied as keyword arguments to initialize() .
class ProfileHandler(RequestHandler): def initialize(self, database): self.database = database def get(self, username): . app = Application([ (r'/user/(.*)', ProfileHandler, dict(database=database)), ])RequestHandler. prepare ( ) → Awaitable [ None ] | None [source] ¶
Called at the beginning of a request before get / post /etc.
Override this method to perform common initialization regardless of the request method.
Asynchronous support: Use async def or decorate this method with gen.coroutine to make it asynchronous. If this method returns an Awaitable execution will not proceed until the Awaitable is done.
Added in version 3.1: Asynchronous support.
RequestHandler. on_finish ( ) → None [source] ¶Called after the end of a request.
Override this method to perform cleanup, logging, etc. This method is a counterpart to prepare . on_finish may not produce any output, as it is called after the response has been sent to the client.
Implement any of the following methods (collectively known as the HTTP verb methods) to handle the corresponding HTTP method. These methods can be made asynchronous with the async def keyword or gen.coroutine decorator.
The arguments to these methods come from the URLSpec : Any capturing groups in the regular expression become arguments to the HTTP verb methods (keyword arguments if the group is named, positional arguments if it’s unnamed).
To support a method not on this list, override the class variable SUPPORTED_METHODS :
class WebDAVHandler(RequestHandler): SUPPORTED_METHODS = RequestHandler.SUPPORTED_METHODS + ('PROPFIND',) def propfind(self): pass
RequestHandler. get ( * args : str , ** kwargs : str ) → None ¶ RequestHandler. head ( * args : str , ** kwargs : str ) → None ¶ RequestHandler. post ( * args : str , ** kwargs : str ) → None ¶ RequestHandler. delete ( * args : str , ** kwargs : str ) → None ¶ RequestHandler. patch ( * args : str , ** kwargs : str ) → None ¶ RequestHandler. put ( * args : str , ** kwargs : str ) → None ¶ RequestHandler. options ( * args : str , ** kwargs : str ) → None ¶
The argument methods provide support for HTML form-style arguments. These methods are available in both singular and plural forms because HTML forms are ambiguous and do not distinguish between a singular argument and a list containing one entry. If you wish to use other formats for arguments (for example, JSON), parse self.request.body yourself:
def prepare(self): if self.request.headers['Content-Type'] == 'application/x-json': self.args = json_decode(self.request.body) # Access self.args directly instead of using self.get_argument.
RequestHandler. get_argument ( name : str , default : str , strip : bool = True ) → str [source] ¶ RequestHandler. get_argument ( name : str , default : _ArgDefaultMarker = _ARG_DEFAULT , strip : bool = True ) → str RequestHandler. get_argument ( name : str , default : None , strip : bool = True ) → str | None
Returns the value of the argument with the given name.
If default is not provided, the argument is considered to be required, and we raise a MissingArgumentError if it is missing.
If the argument appears in the request more than once, we return the last value.
This method searches both the query and body arguments.
RequestHandler. get_arguments ( name : str , strip : bool = True ) → List [ str ] [source] ¶
Returns a list of the arguments with the given name.
If the argument is not present, returns an empty list.
This method searches both the query and body arguments.
RequestHandler. get_query_argument ( name : str , default : str , strip : bool = True ) → str [source] ¶ RequestHandler. get_query_argument ( name : str , default : _ArgDefaultMarker = _ARG_DEFAULT , strip : bool = True ) → str RequestHandler. get_query_argument ( name : str , default : None , strip : bool = True ) → str | None
Returns the value of the argument with the given name from the request query string.
If default is not provided, the argument is considered to be required, and we raise a MissingArgumentError if it is missing.
If the argument appears in the url more than once, we return the last value.
Added in version 3.2.
RequestHandler. get_query_arguments ( name : str , strip : bool = True ) → List [ str ] [source] ¶Returns a list of the query arguments with the given name.
If the argument is not present, returns an empty list.
Added in version 3.2.
RequestHandler. get_body_argument ( name : str , default : str , strip : bool = True ) → str [source] ¶ RequestHandler. get_body_argument ( name : str , default : _ArgDefaultMarker = _ARG_DEFAULT , strip : bool = True ) → str RequestHandler. get_body_argument ( name : str , default : None , strip : bool = True ) → str | None
Returns the value of the argument with the given name from the request body.
If default is not provided, the argument is considered to be required, and we raise a MissingArgumentError if it is missing.
If the argument appears in the url more than once, we return the last value.
Added in version 3.2.
RequestHandler. get_body_arguments ( name : str , strip : bool = True ) → List [ str ] [source] ¶Returns a list of the body arguments with the given name.
If the argument is not present, returns an empty list.
Added in version 3.2.
RequestHandler. decode_argument ( value : bytes , name : str | None = None ) → str [source] ¶Decodes an argument from the request.
The argument has been percent-decoded and is now a byte string. By default, this method decodes the argument as utf-8 and returns a unicode string, but this may be overridden in subclasses.
This method is used as a filter for both get_argument() and for values extracted from the url and passed to get() / post() /etc.
The name of the argument is provided if known, but may be None (e.g. for unnamed groups in the url regex).
The tornado.httputil.HTTPServerRequest object containing additional request parameters including e.g. headers and body data.
RequestHandler. path_args ¶ RequestHandler. path_kwargs ¶
The path_args and path_kwargs attributes contain the positional and keyword arguments that are passed to the HTTP verb methods . These attributes are set before those methods are called, so the values are available during prepare .
Implement this method to handle streamed request data.
May be a coroutine for flow control.
Sets the status code for our response.
Changed in version 5.0: No longer validates that the response code is in http.client.responses .
Sets the given response header name and value.
All header values are converted to strings ( datetime objects are formatted according to the HTTP specification for the Date header).
Adds the given response header and value.
Unlike set_header , add_header may be called multiple times to return multiple values for the same header.
Clears an outgoing header, undoing a previous set_header call.
Note that this method does not apply to multi-valued headers set by add_header .
Override this to set HTTP headers at the beginning of the request.
For example, this is the place to set a custom Server header. Note that setting such headers in the normal flow of request processing may not do what you want, since headers may be reset during error handling.
Writes the given chunk to the output buffer.
To write the output to the network, use the flush() method below.
If the given chunk is a dictionary, we write it as JSON and set the Content-Type of the response to be application/json . (if you want to send JSON as a different Content-Type , call set_header after calling write() ).
Note that lists are not converted to JSON because of a potential cross-site security vulnerability. All JSON output should be wrapped in a dictionary. More details at http://haacked.com/archive/2009/06/25/json-hijacking.aspx/ and https://github.com/facebook/tornado/issues/1009
RequestHandler. flush ( include_footers : bool = False ) → Future [ None ] [source] ¶
Flushes the current output buffer to the network.
Changed in version 4.0: Now returns a Future if no callback is given.
Changed in version 6.0: The callback argument was removed.
RequestHandler. finish ( chunk : str | bytes | dict | None = None ) → Future [ None ] [source] ¶Finishes this response, ending the HTTP request.
Passing a chunk to finish() is equivalent to passing that chunk to write() and then calling finish() with no arguments.
Returns a Future which may optionally be awaited to track the sending of the response to the client. This Future resolves when all the response data has been sent, and raises an error if the connection is closed before all data can be sent.
Changed in version 5.1: Now returns a Future instead of None .
RequestHandler. render ( template_name : str , ** kwargs : Any ) → Future [ None ] [source] ¶Renders the template with the given arguments as the response.
render() calls finish() , so no other output methods can be called after it.
Returns a Future with the same semantics as the one returned by finish . Awaiting this Future is optional.
Changed in version 5.1: Now returns a Future instead of None .
RequestHandler. render_string ( template_name : str , ** kwargs : Any ) → bytes [source] ¶Generate the given template with the given arguments.
We return the generated byte string (in utf8). To generate and write a template as a response, use render() above.
Returns a dictionary to be used as the default template namespace.
May be overridden by subclasses to add or modify values.
The results of this method will be combined with additional defaults in the tornado.template module and keyword arguments to render or render_string .
RequestHandler. redirect ( url : str , permanent : bool = False , status : int | None = None ) → None [source] ¶
Sends a redirect to the given (optionally relative) URL.
If the status argument is specified, that value is used as the HTTP status code; otherwise either 301 (permanent) or 302 (temporary) is chosen based on the permanent argument. The default is 302 (temporary).
RequestHandler. send_error ( status_code : int = 500 , ** kwargs : Any ) → None [source] ¶
Sends the given HTTP error code to the browser.
If flush() has already been called, it is not possible to send an error, so this method will simply terminate the response. If output has been written but not yet flushed, it will be discarded and replaced with the error page.
Override write_error() to customize the error page that is returned. Additional keyword arguments are passed through to write_error .
RequestHandler. write_error ( status_code : int , ** kwargs : Any ) → None [source] ¶
Override to implement custom error pages.
write_error may call write , render , set_header , etc to produce output as usual.
If this error was caused by an uncaught exception (including HTTPError), an exc_info triple will be available as kwargs["exc_info"] . Note that this exception may not be the “current” exception for purposes of methods like sys.exc_info() or traceback.format_exc .
Resets all headers and content for this response.
Default method used to render the final js links for the rendered webpage.
Override this method in a sub-classed controller to change the output.
Default method used to render the final embedded js for the rendered webpage.
Override this method in a sub-classed controller to change the output.
RequestHandler. render_linked_css ( css_files : Iterable [ str ] ) → str [source] ¶
Default method used to render the final css links for the rendered webpage.
Override this method in a sub-classed controller to change the output.
Default method used to render the final embedded css for the rendered webpage.
Override this method in a sub-classed controller to change the output.
RequestHandler. get_cookie ( name : str , default : str ) → str [source] ¶ RequestHandler. get_cookie ( name : str , default : None = None ) → str | None
Returns the value of the request cookie with the given name.
If the named cookie is not present, returns default .
This method only returns cookies that were present in the request. It does not see the outgoing cookies set by set_cookie in this handler.
RequestHandler. set_cookie ( name : str , value : str | bytes , domain : str | None = None , expires : float | Tuple | datetime | None = None , path : str = '/' , expires_days : float | None = None , * , max_age : int | None = None , httponly : bool = False , secure : bool = False , samesite : str | None = None , ** kwargs : Any ) → None [source] ¶
Sets an outgoing cookie name/value with the given options.
Newly-set cookies are not immediately visible via get_cookie ; they are not present until the next request.
expires may be a numeric timestamp as returned by time.time , a time tuple as returned by time.gmtime , or a datetime.datetime object. expires_days is provided as a convenience to set an expiration time in days from today (if both are set, expires is used).
Deprecated since version 6.3: Keyword arguments are currently accepted case-insensitively. In Tornado 7.0 this will be changed to only accept lowercase arguments.
RequestHandler. clear_cookie ( name : str , ** kwargs : Any ) → None [source] ¶Deletes the cookie with the given name.
This method accepts the same arguments as set_cookie , except for expires and max_age . Clearing a cookie requires the same domain and path arguments as when it was set. In some cases the samesite and secure arguments are also required to match. Other arguments are ignored.
Similar to set_cookie , the effect of this method will not be seen until the following request.
Changed in version 6.3: Now accepts all keyword arguments that set_cookie does. The samesite and secure flags have recently become required for clearing samesite="none" cookies.
RequestHandler. clear_all_cookies ( ** kwargs : Any ) → None [source] ¶Attempt to delete all the cookies the user sent with this request.
See clear_cookie for more information on keyword arguments. Due to limitations of the cookie protocol, it is impossible to determine on the server side which values are necessary for the domain , path , samesite , or secure arguments, this method can only be successful if you consistently use the same values for these arguments when setting cookies.
Similar to set_cookie , the effect of this method will not be seen until the following request.
Changed in version 3.2: Added the path and domain parameters.
Changed in version 6.3: Now accepts all keyword arguments that set_cookie does.
Deprecated since version 6.3: The increasingly complex rules governing cookies have made it impossible for a clear_all_cookies method to work reliably since all we know about cookies are their names. Applications should generally use clear_cookie one at a time instead.
RequestHandler. get_signed_cookie ( name : str , value : str | None = None , max_age_days : float = 31 , min_version : int | None = None ) → bytes | None [source] ¶
Returns the given signed cookie if it validates, or None.
The decoded cookie value is returned as a byte string (unlike get_cookie ).
Similar to get_cookie , this method only returns cookies that were present in the request. It does not see outgoing cookies set by set_signed_cookie in this handler.
Changed in version 3.2.1:
Added the min_version argument. Introduced cookie version 2; both versions 1 and 2 are accepted by default.
Changed in version 6.3: Renamed from get_secure_cookie to get_signed_cookie to avoid confusion with other uses of “secure” in cookie attributes and prefixes. The old name remains as an alias.
RequestHandler. get_signed_cookie_key_version ( name : str , value : str | None = None ) → int | None [source] ¶
Returns the signing key version of the secure cookie.
The version is returned as int.
Changed in version 6.3: Renamed from get_secure_cookie_key_version to set_signed_cookie_key_version to avoid confusion with other uses of “secure” in cookie attributes and prefixes. The old name remains as an alias.
RequestHandler. set_signed_cookie ( name : str , value : str | bytes , expires_days : float | None = 30 , version : int | None = None , ** kwargs : Any ) → None [source] ¶
Signs and timestamps a cookie so it cannot be forged.
You must specify the cookie_secret setting in your Application to use this method. It should be a long, random sequence of bytes to be used as the HMAC secret for the signature.
To read a cookie set with this method, use get_signed_cookie() .
Note that the expires_days parameter sets the lifetime of the cookie in the browser, but is independent of the max_age_days parameter to get_signed_cookie . A value of None limits the lifetime to the current browser session.
Secure cookies may contain arbitrary byte values, not just unicode strings (unlike regular cookies)
Similar to set_cookie , the effect of this method will not be seen until the following request.
Changed in version 3.2.1: Added the version argument. Introduced cookie version 2 and made it the default.
Changed in version 6.3: Renamed from set_secure_cookie to set_signed_cookie to avoid confusion with other uses of “secure” in cookie attributes and prefixes. The old name remains as an alias.
RequestHandler. get_secure_cookie ( ) ¶Deprecated alias for get_signed_cookie .
Deprecated since version 6.3.
RequestHandler. get_secure_cookie_key_version ( ) ¶Deprecated alias for get_signed_cookie_key_version .
Deprecated since version 6.3.
RequestHandler. set_secure_cookie ( ) ¶Deprecated alias for set_signed_cookie .
Deprecated since version 6.3.
RequestHandler. create_signed_value ( name : str , value : str | bytes , version : int | None = None ) → bytes [source] ¶
Signs and timestamps a string so it cannot be forged.
Normally used via set_signed_cookie, but provided as a separate method for non-cookie uses. To decode a value not stored as a cookie use the optional value argument to get_signed_cookie.
Changed in version 3.2.1: Added the version argument. Introduced cookie version 2 and made it the default.
tornado.web. MIN_SUPPORTED_SIGNED_VALUE_VERSION = 1 ¶The oldest signed value version supported by this version of Tornado.
Signed values older than this version cannot be decoded.
Added in version 3.2.1.
tornado.web. MAX_SUPPORTED_SIGNED_VALUE_VERSION = 2 ¶The newest signed value version supported by this version of Tornado.
Signed values newer than this version cannot be decoded.
Added in version 3.2.1.
tornado.web. DEFAULT_SIGNED_VALUE_VERSION = 2 ¶May be overridden by passing a version keyword argument.
Added in version 3.2.1.
tornado.web. DEFAULT_SIGNED_VALUE_MIN_VERSION = 1 ¶The oldest signed value accepted by RequestHandler.get_signed_cookie .
May be overridden by passing a min_version keyword argument.
Added in version 3.2.1.
The Application object serving this request
Checks the Etag header against requests’s If-None-Match .
Returns True if the request’s Etag matches and a 304 should be returned. For example:
self.set_etag_header() if self.check_etag_header(): self.set_status(304) return
This method is called automatically when the request is finished, but may be called earlier for applications that override compute_etag and want to do an early check for If-None-Match before completing the request. The Etag header should be set (perhaps with set_etag_header ) before calling this method.
Verifies that the _xsrf cookie matches the _xsrf argument.
To prevent cross-site request forgery, we set an _xsrf cookie and include the same value as a non-cookie field with all POST requests. If the two do not match, we reject the form submission as a potential forgery.
The _xsrf value may be set as either a form field named _xsrf or in a custom HTTP header named X-XSRFToken or X-CSRFToken (the latter is accepted for compatibility with Django).
Changed in version 3.2.2: Added support for cookie version 2. Both versions 1 and 2 are supported.
RequestHandler. compute_etag ( ) → str | None [source] ¶Computes the etag header to be used for this request.
By default uses a hash of the content written so far.
May be overridden to provide custom etag implementations, or may return None to disable tornado’s default etag support.
RequestHandler. create_template_loader ( template_path : str ) → BaseLoader [source] ¶
Returns a new template loader for the given path.
May be overridden by subclasses. By default returns a directory-based loader on the given path, using the autoescape and template_whitespace application settings. If a template_loader application setting is supplied, uses that instead.
The authenticated user for this request.
This is set in one of two ways:
def get_current_user(self): user_cookie = self.get_signed_cookie("user") if user_cookie: return json.loads(user_cookie) return None
@gen.coroutine def prepare(self): user_id_cookie = self.get_signed_cookie("user_id") if user_id_cookie: self.current_user = yield load_user(user_id_cookie)
Note that prepare() may be a coroutine while get_current_user() may not, so the latter form is necessary if loading the user requires asynchronous operations.
The user object may be any type of the application’s choosing.
Take control of the underlying stream.
Returns the underlying IOStream object and stops all further HTTP processing. Intended for implementing protocols like websockets that tunnel over an HTTP handshake.
This method is only supported when HTTP/1.1 is used.
Added in version 5.1.
RequestHandler. get_browser_locale ( default : str = 'en_US' ) → Locale [source] ¶Determines the user’s locale from Accept-Language header.
Override to determine the current user from, e.g., a cookie.
This method may not be a coroutine.
Override to customize the login URL based on the request.
By default, we use the login_url application setting.
Returns the status code for our response.
Override to customize template path for each handler.
By default, we use the template_path application setting. Return None to load templates relative to the calling file.
Override to determine the locale from the authenticated user.
If None is returned, we fall back to get_browser_locale() .
This method should return a tornado.locale.Locale object, most likely obtained via a call like tornado.locale.get("en")
The locale for the current session.
Determined by either get_user_locale , which you can override to set the locale based on, e.g., a user preference stored in a database, or get_browser_locale , which uses the Accept-Language header.
Override to customize logging of uncaught exceptions.
By default logs instances of HTTPError as warnings without stack traces (on the tornado.general logger), and all other exceptions as errors with stack traces (on the tornado.application logger).
Added in version 3.1.
RequestHandler. on_connection_close ( ) → None [source] ¶Called in async handlers if the client closed the connection.
Override this to clean up resources associated with long-lived connections. Note that this method is called only if the connection was closed during asynchronous processing; if you need to do cleanup after every request override on_finish instead.
Proxies may keep a connection open for a time (perhaps indefinitely) after the client has gone away, so this method may not be called promptly after the end user closes their connection.
RequestHandler. require_setting ( name : str , feature : str = 'this feature' ) → None [source] ¶
Raises an exception if the given app setting is not defined.
Sets the response’s Etag header using self.compute_etag() .
Note: no header will be set if compute_etag() returns None .
This method is called automatically when the request is finished.
RequestHandler. static_url ( path : str , include_host : bool | None = None , ** kwargs : Any ) → str [source] ¶
Returns a static URL for the given relative static file path.
This method requires you set the static_path setting in your application (which specifies the root directory of your static files).
This method returns a versioned url (by default appending ?v= ), which allows the static files to be cached indefinitely. This can be disabled by passing include_version=False (in the default implementation; other static file implementations are not required to support this, but they may support other options).
By default this method returns URLs relative to the current host, but if include_host is true the URL returned will be absolute. If this handler has an include_host attribute, that value will be used as the default for all static_url calls that do not pass include_host as a keyword argument.
An HTML element to be included with all POST forms.
It defines the _xsrf input value, which we check on all POST requests to prevent cross-site request forgery. If you have set the xsrf_cookies application setting, you must include this HTML within all of your HTML forms.
In a template, this method should be called with
See check_xsrf_cookie() above for more information.
The XSRF-prevention token for the current user/session.
To prevent cross-site request forgery, we set an ‘_xsrf’ cookie and include the same ‘_xsrf’ value as an argument with all POST requests. If the two do not match, we reject the form submission as a potential forgery.
This property is of type bytes , but it contains only ASCII characters. If a character string is required, there is no need to base64-encode it; just decode the byte string as UTF-8.
Changed in version 3.2.2: The xsrf token will now be have a random mask applied in every request, which makes it safe to include the token in pages that are compressed. See http://breachattack.com for more information on the issue fixed by this change. Old (version 1) cookies will be converted to version 2 when this method is called unless the xsrf_cookie_version Application setting is set to 1.
Changed in version 4.3: The xsrf_cookie_kwargs Application setting may be used to supply additional cookie options (which will be passed directly to set_cookie ). For example, xsrf_cookie_kwargs=dict(httponly=True, secure=True) will set the secure and httponly flags on the _xsrf cookie.
class tornado.web. Application ( handlers : List [ Rule | Tuple ] | None = None , default_host : str | None = None , transforms : List [ Type [ OutputTransform ] ] | None = None , ** settings ) [source] ¶
A collection of request handlers that make up a web application.
Instances of this class are callable and can be passed directly to HTTPServer to serve the application:
application = web.Application([ (r"/", MainPageHandler), ]) http_server = httpserver.HTTPServer(application) http_server.listen(8080)
The constructor for this class takes in a list of Rule objects or tuples of values corresponding to the arguments of Rule constructor: (matcher, target, [target_kwargs], [name]) , the values in square brackets being optional. The default matcher is PathMatches , so (regexp, target) tuples can also be used instead of (PathMatches(regexp), target) .
A common routing target is a RequestHandler subclass, but you can also use lists of rules as a target, which create a nested routing configuration:
application = web.Application([ (HostMatches("example.com"), [ (r"/", MainPageHandler), (r"/feed", FeedHandler), ]), ])
In addition to this you can use nested Router instances, HTTPMessageDelegate subclasses and callables as routing targets (see routing module docs for more information).
When we receive requests, we iterate over the list in order and instantiate an instance of the first request class whose regexp matches the request path. The request class can be specified as either a class object or a (fully-qualified) name.
A dictionary may be passed as the third element ( target_kwargs ) of the tuple, which will be used as keyword arguments to the handler’s constructor and initialize method. This pattern is used for the StaticFileHandler in this example (note that a StaticFileHandler can be installed automatically with the static_path setting described below):
application = web.Application([ (r"/static/(.*)", web.StaticFileHandler, "path": "/var/www">), ])
We support virtual hosts with the add_handlers method, which takes in a host regular expression as the first argument:
application.add_handlers(r"www\.myhost\.com", [ (r"/article/([0-9]+)", ArticleHandler), ])
If there’s no match for the current request’s host, then default_host parameter value is matched against host regular expressions.
Applications that do not use TLS may be vulnerable to DNS rebinding attacks. This attack is especially relevant to applications that only listen on 127.0.0.1 or other private networks. Appropriate host patterns must be used (instead of the default of r'.*' ) to prevent this risk. The default_host argument must not be used in applications that may be vulnerable to DNS rebinding.
You can serve static files by sending the static_path setting as a keyword argument. We will serve those files from the /static/ URI (this is configurable with the static_url_prefix setting), and we will serve /favicon.ico and /robots.txt from the same directory. A custom subclass of StaticFileHandler can be specified with the static_handler_class setting.
Changed in version 4.5: Integration with the new tornado.routing module.
Additional keyword arguments passed to the constructor are saved in the settings dictionary, and are often referred to in documentation as “application settings”. Settings are used to customize various aspects of Tornado (although in some cases richer customization is possible by overriding methods in a subclass of RequestHandler ). Some applications also like to use the settings dictionary as a way to make application-specific settings available to handlers without using global variables. Settings used in Tornado are described below.
Authentication and security settings:
Static file settings:
Starts an HTTP server for this application on the given port.
This is a convenience alias for creating an HTTPServer object and calling its listen method. Keyword arguments not supported by HTTPServer.listen are passed to the HTTPServer constructor. For advanced uses (e.g. multi-process mode), do not use this method; create an HTTPServer and call its TCPServer.bind / TCPServer.start methods directly.
Note that after calling this method you still need to call IOLoop.current().start() (or run within asyncio.run ) to start the server.
Returns the HTTPServer object.
Changed in version 4.3: Now returns the HTTPServer object.
Changed in version 6.2: Added support for new keyword arguments in TCPServer.listen , including reuse_port .
Application. add_handlers ( handlers : List [ Rule | Tuple ] ) [source] ¶Appends the given handlers to our handler list.
Host patterns are processed sequentially in the order they were added. All matching patterns will be considered.
Application. get_handler_delegate ( request : HTTPServerRequest , target_class : Type [ RequestHandler ] , target_kwargs : Dict [ str , Any ] | None = None , path_args : List [ bytes ] | None = None , path_kwargs : Dict [ str , bytes ] | None = None ) → _HandlerDelegate [source] ¶
Returns HTTPMessageDelegate that can serve a request for application and RequestHandler subclass.
Returns a URL path for handler named name
The handler must be added to the application as a named URLSpec .
Args will be substituted for capturing groups in the URLSpec regex. They will be converted to strings if necessary, encoded as utf8, and url-escaped.
Writes a completed HTTP request to the logs.
By default writes to the python root logger. To change this behavior either subclass Application and override this method, or pass a function in the application settings dictionary as log_function .
class tornado.web. URLSpec ( pattern : str | Pattern , handler : Any , kwargs : Dict [ str , Any ] | None = None , name : str | None = None ) [source] ¶
Specifies mappings between URLs and handlers.
The URLSpec class is also available under the name tornado.web.url .
Decorate methods with this to require that the user be logged in.
If the user is not logged in, they will be redirected to the configured login url .
If you configure a login url with a query parameter, Tornado will assume you know what you’re doing and use it as-is. If not, it will add a next parameter so the login page knows where to send you once you’re logged in.
Use this decorator to add a missing trailing slash to the request path.
For example, a request to /foo would redirect to /foo/ with this decorator. Your request handler mapping should use a regular expression like r'/foo/?' in conjunction with using the decorator.
Use this decorator to remove trailing slashes from the request path.
For example, a request to /foo/ would redirect to /foo with this decorator. Your request handler mapping should use a regular expression like r'/foo/*' in conjunction with using the decorator.
tornado.web. stream_request_body ( cls : Type [ _RequestHandlerType ] ) → Type [ _RequestHandlerType ] [source] ¶
Apply to RequestHandler subclasses to enable streaming body support.
This decorator implies the following changes:
See the file receiver demo for example usage.
exception tornado.web. HTTPError ( status_code : int = 500 , log_message : str | None = None , * args : Any , ** kwargs : Any ) [source] ¶
An exception that will turn into an HTTP error response.
Raising an HTTPError is a convenient alternative to calling RequestHandler.send_error since it automatically ends the current function.
To customize the response sent with an HTTPError , override RequestHandler.write_error .
An exception that ends the request without producing an error response.
When Finish is raised in a RequestHandler , the request will end (calling RequestHandler.finish if it hasn’t already been called), but the error-handling methods (including RequestHandler.write_error ) will not be called.
If Finish() was created with no arguments, the pending response will be sent as-is. If Finish() was given an argument, that argument will be passed to RequestHandler.finish() .
This can be a more convenient way to implement custom error pages than overriding write_error (especially in library code):
if self.current_user is None: self.set_status(401) self.set_header('WWW-Authenticate', 'Basic realm="something"') raise Finish()
Changed in version 4.3: Arguments passed to Finish() will be passed on to RequestHandler.finish .
exception tornado.web. MissingArgumentError ( arg_name : str ) [source] ¶This is a subclass of HTTPError , so if it is uncaught a 400 response code will be used instead of 500 (and a stack trace will not be logged).
Added in version 3.1.
class tornado.web. UIModule ( handler : RequestHandler ) [source] ¶A re-usable, modular UI unit on a page.
UI modules often execute additional queries, and they can include additional CSS and JavaScript that will be included in the output page, which is automatically inserted on page render.
Subclasses of UIModule must override the render method.
Override in subclasses to return this module’s output.
Override to return a JavaScript string to be embedded in the page.
Override to return a list of JavaScript files needed by this module.
If the return values are relative paths, they will be passed to RequestHandler.static_url ; otherwise they will be used as-is.
Override to return a CSS string that will be embedded in the page.
Override to returns a list of CSS files required by this module.
If the return values are relative paths, they will be passed to RequestHandler.static_url ; otherwise they will be used as-is.
Override to return an HTML string that will be put in the element.
Override to return an HTML string that will be put at the end of the element.
Renders a template and returns it as a string.
Generates an error response with status_code for all requests.
A RequestHandler that wraps another HTTP server callback.
The fallback is a callable object that accepts an HTTPServerRequest , such as an Application or tornado.wsgi.WSGIContainer . This is most useful to use both Tornado RequestHandlers and WSGI in the same server. Typical usage:
wsgi_app = tornado.wsgi.WSGIContainer( django.core.handlers.wsgi.WSGIHandler()) application = tornado.web.Application([ (r"/foo", FooHandler), (r".*", FallbackHandler, dict(fallback=wsgi_app)), ])
Redirects the client to the given URL for all GET requests.
You should provide the keyword argument url to the handler, e.g.:
application = web.Application([ (r"/oldpath", web.RedirectHandler, "url": "/newpath">), ])
RedirectHandler supports regular expression substitutions. E.g., to swap the first and second parts of a path while preserving the remainder:
application = web.Application([ (r"/(.*?)/(.*?)/(.*)", web.RedirectHandler, "url": "/ / / ">), ])
The final URL is formatted with str.format and the substrings that match the capturing groups. In the above example, a request to “/a/b/c” would be formatted like:
str.format("/ / / ", "a", "b", "c") # -> "/b/a/c"
Use Python’s format string syntax to customize how values are substituted.
Changed in version 4.5: Added support for substitutions into the destination URL.
Changed in version 5.0: If any query arguments are present, they will be copied to the destination URL.
A simple handler that can serve static content from a directory.
A StaticFileHandler is configured automatically if you pass the static_path keyword argument to Application . This handler can be customized with the static_url_prefix , static_handler_class , and static_handler_args settings.
To map an additional path to this handler for a static data directory you would add a line to your application like:
application = web.Application([ (r"/content/(.*)", web.StaticFileHandler, "path": "/var/www">), ])
The handler constructor requires a path argument, which specifies the local root directory of the content to be served.
Note that a capture group in the regex is required to parse the value for the path argument to the get() method (different than the constructor argument above); see URLSpec for details.
To serve a file like index.html automatically when a directory is requested, set static_handler_args=dict(default_filename="index.html") in your application settings, or add default_filename as an initializer argument for your StaticFileHandler .
To maximize the effectiveness of browser caching, this class supports versioned urls (by default using the argument ?v= ). If a version is given, we instruct the browser to cache this file indefinitely. make_static_url (also available as RequestHandler.static_url ) can be used to construct a versioned url.
This handler is intended primarily for use in development and light-duty file serving; for heavy traffic it will be more efficient to use a dedicated static file server (such as nginx or Apache). We support the HTTP Accept-Ranges mechanism to return partial content (because some browsers require this functionality to be present to seek in HTML5 audio or video).
Subclassing notes
This class is designed to be extensible by subclassing, but because of the way static urls are generated with class methods rather than instance methods, the inheritance patterns are somewhat unusual. Be sure to use the @classmethod decorator when overriding a class method. Instance methods may use the attributes self.path self.absolute_path , and self.modified .
Subclasses should only override methods discussed in this section; overriding other methods is error-prone. Overriding StaticFileHandler.get is particularly problematic due to the tight coupling with compute_etag and other methods.
To change the way static urls are generated (e.g. to match the behavior of another server or CDN), override make_static_url , parse_url_path , get_cache_time , and/or get_version .
To replace all interaction with the filesystem (e.g. to serve static content from a database), override get_content , get_content_size , get_modified_time , get_absolute_path , and validate_absolute_path .
Changed in version 3.1: Many of the methods for subclasses were added in Tornado 3.1.
compute_etag ( ) → str | None [source] ¶Sets the Etag header based on static url version.
This allows efficient If-None-Match checks against cached versions, and sends the correct Etag for a partial response (i.e. the same Etag as the full file).
Added in version 3.1.
set_headers ( ) → None [source] ¶Sets the content and caching headers on the response.
Added in version 3.1.
should_return_304 ( ) → bool [source] ¶Returns True if the headers indicate that we should return 304.
Added in version 3.1.
classmethod get_absolute_path ( root : str , path : str ) → str [source] ¶Returns the absolute location of path relative to root .
root is the path configured for this StaticFileHandler (in most cases the static_path Application setting).
This class method may be overridden in subclasses. By default it returns a filesystem path, but other strings may be used as long as they are unique and understood by the subclass’s overridden get_content .
Added in version 3.1.
validate_absolute_path ( root : str , absolute_path : str ) → str | None [source] ¶Validate and return the absolute path.
root is the configured path for the StaticFileHandler , and path is the result of get_absolute_path
This is an instance method called during request processing, so it may raise HTTPError or use methods like RequestHandler.redirect (return None after redirecting to halt further processing). This is where 404 errors for missing files are generated.
This method may modify the path before returning it, but note that any such modifications will not be understood by make_static_url .
In instance methods, this method’s result is available as self.absolute_path .
Added in version 3.1.
Retrieve the content of the requested resource which is located at the given absolute path.
This class method may be overridden by subclasses. Note that its signature is different from other overridable class methods (no settings argument); this is deliberate to ensure that abspath is able to stand on its own as a cache key.
This method should either return a byte string or an iterator of byte strings. The latter is preferred for large files as it helps reduce memory fragmentation.
Added in version 3.1.
classmethod get_content_version ( abspath : str ) → str [source] ¶Returns a version string for the resource at the given path.
This class method may be overridden by subclasses. The default implementation is a SHA-512 hash of the file’s contents.
Added in version 3.1.
get_content_size ( ) → int [source] ¶Retrieve the total size of the resource at the given path.
This method may be overridden by subclasses.
Added in version 3.1.
Changed in version 4.0: This method is now always called, instead of only when partial results are requested.
get_modified_time ( ) → datetime | None [source] ¶Returns the time that self.absolute_path was last modified.
May be overridden in subclasses. Should return a datetime object or None.
Added in version 3.1.
Changed in version 6.4: Now returns an aware datetime object instead of a naive one. Subclasses that override this method may return either kind.
get_content_type ( ) → str [source] ¶Returns the Content-Type header to be used for this request.
Added in version 3.1.
set_extra_headers ( path : str ) → None [source] ¶For subclass to add extra headers to the response
Override to customize cache control behavior.
Return a positive number of seconds to make the result cacheable for that amount of time or 0 to mark resource as cacheable for an unspecified amount of time (subject to browser heuristics).
By default returns cache expiry of 10 years for resources requested with v argument.
classmethod make_static_url ( settings : Dict [ str , Any ] , path : str , include_version : bool = True ) → str [source] ¶
Constructs a versioned url for the given path.
This method may be overridden in subclasses (but note that it is a class method rather than an instance method). Subclasses are only required to implement the signature make_static_url(cls, settings, path) ; other keyword arguments may be passed through static_url but are not standard.
settings is the Application.settings dictionary. path is the static path being requested. The url returned should be relative to the current host.
include_version determines whether the generated URL should include the query string containing the version hash of the file corresponding to the given path .
Converts a static URL path into a filesystem path.
url_path is the path component of the URL with static_url_prefix removed. The return value should be filesystem path relative to static_path .
This is the inverse of make_static_url .
Generate the version string to be used in static URLs.
settings is the Application.settings dictionary and path is the relative location of the requested asset on the filesystem. The returned value should be a string, or None if no version could be determined.
Changed in version 3.1: This method was previously recommended for subclasses to override; get_content_version is now preferred as it allows the base class to handle caching of the result.
© Copyright The Tornado Authors. Revision fe1e98c7 .