.. _guide.request: Request data ============ The request handler instance can access the request data using its ``request`` property. This is initialized to a populated `WebOb`_ ``Request`` object by the application. The request object provides a ``get()`` method that returns values for arguments parsed from the query and from POST data. The method takes the argument name as its first parameter. For example:: class MyHandler(webapp2.RequestHandler): def post(self): name = self.request.get('name') By default, ``get()`` returns the empty string (``''``) if the requested argument is not in the request. If the parameter ``default_value`` is specified, ``get()`` returns the value of that parameter instead of the empty string if the argument is not present. If the argument appears more than once in a request, by default ``get()`` returns the first occurrence. To get all occurrences of an argument that might appear more than once as a list (possibly empty), give ``get()`` the argument ``allow_multiple=True``:: # name = self.request.get("name") # subscribe_to_newsletter = self.request.get("subscribe", default_value="no") # favorite_foods = self.request.get("favorite_foods", allow_multiple=True) # for food in favorite_foods: # ... For requests with body content that is not a set of CGI parameters, such as the body of an HTTP PUT request, the request object provides the attributes ``body`` and ``body_file``: ``body`` is the body content as a byte string and ``body_file`` provides a file-like interface to the same data:: uploaded_file = self.request.body GET data -------- Query string variables are available in ``request.GET``. ``.GET`` is a `MultiDict`_: it is like a dictionary but the same key can have multiple values. When you call ``.get(key)`` for a key with multiple values, the last value is returned. To get all values for a key, use ``.getall(key)``. Examples:: request = Request.blank('/test?check=a&check=b&name=Bob') # The whole MultiDict: # GET([('check', 'a'), ('check', 'b'), ('name', 'Bob')]) get_values = request.GET # The last value for a key: 'b' check_value = request.GET['check'] # All values for a key: ['a', 'b'] check_values = request.GET.getall('check') # An iterable with alll items in the MultiDict: # [('check', 'a'), ('check', 'b'), ('name', 'Bob')] request.GET.items() The name ``GET`` is a bit misleading, but has historical reasons: ``request.GET`` is not only available when the HTTP method is GET. It is available for any request with query strings in the URI, for any HTTP method: GET, POST, PUT etc. POST data --------- Variables url encoded in the body of a request (generally a POST form submitted using the ``application/x-www-form-urlencoded`` media type) are available in ``request.POST``. It is also a `MultiDict`_ and can be accessed in the same way as ``.GET``. Examples:: request = Request.blank('/') request.method = 'POST' request.body = 'check=a&check=b&name=Bob' # The whole MultiDict: # POST([('check', 'a'), ('check', 'b'), ('name', 'Bob')]) post_values = request.POST # The last value for a key: 'b' check_value = request.POST['check'] # All values for a key: ['a', 'b'] check_values = request.POST.getall('check') # An iterable with alll items in the MultiDict: # [('check', 'a'), ('check', 'b'), ('name', 'Bob')] request.POST.items() Like ``GET``, the name ``POST`` is a somewjat misleading, but has historical reasons: they are also available when the HTTP method is PUT, and not only POST. GET + POST data --------------- ``request.params`` combines the variables from ``GET`` and ``POST``. It can be used when you don't care where the variable comes from. Files ----- Uploaded files are available as ``cgi.FieldStorage`` (see the :py:mod:`cgi` module) instances directly in ``request.POST``. .. _guide.request.cookies: Cookies ------- Cookies can be accessed in ``request.cookies``. It is a simple dictionary:: request = Request.blank('/') request.headers['Cookie'] = 'test=value' # A value: 'value' cookie_value = request.cookies.get('test') .. seealso:: :ref:`How to set cookies using the response object ` Common Request attributes ------------------------- body A file-like object that gives the body of the request. content_type Content-type of the request body. method The HTTP method, e.g., 'GET' or 'POST'. url Full URI, e.g., ``'http://localhost/blog/article?id=1'``. scheme URI scheme, e.g., 'http' or 'https'. host URI host, e.g., ``'localhost:80'``. host_url URI host including scheme, e.g., ``'http://localhost'``. path_url URI host including scheme and path, e.g., ``'http://localhost/blog/article'``. path URI path, e.g., ``'/blog/article'``. path_qs URI path including the query string, e.g., ``'/blog/article?id=1'``. query_string Query string, e.g., ``id=1``. headers A dictionary like object with request headers. Keys are case-insensitive. GET A dictionary-like object with variables from the query string, as unicode. POST A dictionary-like object with variables from a POST form, as unicode. params A dictionary-like object combining the variables GET and POST. cookies A dictionary-like object with cookie values. Extra attributes ---------------- The parameters from the matched :class:`webapp2.Route` are set as attributes of the request object. They are ``request.route_args``, for positional arguments, and ``request.route_kwargs``, for keyword arguments. The matched route object is available as ``request.route``. A reference to the active WSGI application is also set as an attribute of the request. You can access it in ``request.app``. Getting the current request --------------------------- The active ``Request`` instance can be accessed during a request using the function :func:`webapp2.get_request`. .. _guide.request.registry: Registry -------- A simple dictionary is available in the request object to register instances that are shared during a request: it is the :attr:`webapp2.Request.registry` attribute. A registry dictionary is also available in the :ref:`WSGI application object `, to store objects shared across requests. Learn more about WebOb ---------------------- WebOb is an open source third-party library. See the `WebOb`_ documentation for a detailed API reference and examples. .. _WebOb: http://docs.webob.org/ .. _MultiDict: http://pythonpaste.org/webob/class-webob.multidict.MultiDict.html