2017-09-13 15:24:12 -04:00
|
|
|
=============================================
|
|
|
|
``django.urls`` functions for use in URLconfs
|
|
|
|
=============================================
|
|
|
|
|
|
|
|
.. module:: django.urls.conf
|
|
|
|
:synopsis: Functions for use in URLconfs.
|
|
|
|
|
2016-10-20 19:29:04 +02:00
|
|
|
.. currentmodule:: django.urls
|
|
|
|
|
|
|
|
``path()``
|
|
|
|
==========
|
|
|
|
|
|
|
|
.. function:: path(route, view, kwargs=None, name=None)
|
|
|
|
|
|
|
|
Returns an element for inclusion in ``urlpatterns``. For example::
|
|
|
|
|
|
|
|
from django.urls import include, path
|
|
|
|
|
|
|
|
urlpatterns = [
|
2023-03-01 13:35:43 +01:00
|
|
|
path("index/", views.index, name="main-view"),
|
|
|
|
path("bio/<username>/", views.bio, name="bio"),
|
|
|
|
path("articles/<slug:title>/", views.article, name="article-detail"),
|
|
|
|
path("articles/<slug:title>/<int:section>/", views.section, name="article-section"),
|
|
|
|
path("blog/", include("blog.urls")),
|
|
|
|
...,
|
2016-10-20 19:29:04 +02:00
|
|
|
]
|
|
|
|
|
|
|
|
The ``route`` argument should be a string or
|
|
|
|
:func:`~django.utils.translation.gettext_lazy()` (see
|
|
|
|
:ref:`translating-urlpatterns`) that contains a URL pattern. The string
|
|
|
|
may contain angle brackets (like ``<username>`` above) to capture part of the
|
|
|
|
URL and send it as a keyword argument to the view. The angle brackets may
|
|
|
|
include a converter specification (like the ``int`` part of ``<int:section>``)
|
|
|
|
which limits the characters matched and may also change the type of the
|
|
|
|
variable passed to the view. For example, ``<int:section>`` matches a string
|
|
|
|
of decimal digits and converts the value to an ``int``. See
|
|
|
|
:ref:`how-django-processes-a-request` for more details.
|
|
|
|
|
|
|
|
The ``view`` argument is a view function or the result of
|
|
|
|
:meth:`~django.views.generic.base.View.as_view` for class-based views. It can
|
|
|
|
also be an :func:`django.urls.include`.
|
|
|
|
|
|
|
|
The ``kwargs`` argument allows you to pass additional arguments to the view
|
|
|
|
function or method. See :ref:`views-extra-options` for an example.
|
|
|
|
|
|
|
|
See :ref:`Naming URL patterns <naming-url-patterns>` for why the ``name``
|
|
|
|
argument is useful.
|
|
|
|
|
|
|
|
``re_path()``
|
|
|
|
=============
|
|
|
|
|
|
|
|
.. function:: re_path(route, view, kwargs=None, name=None)
|
|
|
|
|
|
|
|
Returns an element for inclusion in ``urlpatterns``. For example::
|
|
|
|
|
|
|
|
from django.urls import include, re_path
|
|
|
|
|
|
|
|
urlpatterns = [
|
2023-03-01 13:35:43 +01:00
|
|
|
re_path(r"^index/$", views.index, name="index"),
|
|
|
|
re_path(r"^bio/(?P<username>\w+)/$", views.bio, name="bio"),
|
|
|
|
re_path(r"^blog/", include("blog.urls")),
|
|
|
|
...,
|
2016-10-20 19:29:04 +02:00
|
|
|
]
|
|
|
|
|
|
|
|
The ``route`` argument should be a string or
|
|
|
|
:func:`~django.utils.translation.gettext_lazy()` (see
|
|
|
|
:ref:`translating-urlpatterns`) that contains a regular expression compatible
|
|
|
|
with Python's :py:mod:`re` module. Strings typically use raw string syntax
|
|
|
|
(``r''``) so that they can contain sequences like ``\d`` without the need to
|
|
|
|
escape the backslash with another backslash. When a match is made, captured
|
|
|
|
groups from the regular expression are passed to the view -- as named arguments
|
|
|
|
if the groups are named, and as positional arguments otherwise. The values are
|
|
|
|
passed as strings, without any type conversion.
|
|
|
|
|
2021-12-15 18:54:02 +01:00
|
|
|
When a ``route`` ends with ``$`` the whole requested URL, matching against
|
|
|
|
:attr:`~django.http.HttpRequest.path_info`, must match the regular expression
|
|
|
|
pattern (:py:func:`re.fullmatch` is used).
|
|
|
|
|
2016-10-20 19:29:04 +02:00
|
|
|
The ``view``, ``kwargs`` and ``name`` arguments are the same as for
|
|
|
|
:func:`~django.urls.path()`.
|
2017-09-13 15:24:12 -04:00
|
|
|
|
2021-12-15 18:54:02 +01:00
|
|
|
.. versionchanged:: 2.2.25
|
|
|
|
|
|
|
|
In older versions, a full-match wasn't required for a ``route`` which ends
|
|
|
|
with ``$``.
|
|
|
|
|
2017-09-13 15:24:12 -04:00
|
|
|
``include()``
|
|
|
|
=============
|
|
|
|
|
|
|
|
.. function:: include(module, namespace=None)
|
|
|
|
include(pattern_list)
|
|
|
|
include((pattern_list, app_namespace), namespace=None)
|
|
|
|
|
|
|
|
A function that takes a full Python import path to another URLconf module
|
|
|
|
that should be "included" in this place. Optionally, the :term:`application
|
|
|
|
namespace` and :term:`instance namespace` where the entries will be included
|
|
|
|
into can also be specified.
|
|
|
|
|
|
|
|
Usually, the application namespace should be specified by the included
|
|
|
|
module. If an application namespace is set, the ``namespace`` argument
|
|
|
|
can be used to set a different instance namespace.
|
|
|
|
|
|
|
|
``include()`` also accepts as an argument either an iterable that returns
|
|
|
|
URL patterns or a 2-tuple containing such iterable plus the names of the
|
|
|
|
application namespaces.
|
|
|
|
|
|
|
|
:arg module: URLconf module (or module name)
|
|
|
|
:arg namespace: Instance namespace for the URL entries being included
|
2018-02-12 09:09:46 -05:00
|
|
|
:type namespace: str
|
2016-10-20 19:29:04 +02:00
|
|
|
:arg pattern_list: Iterable of :func:`~django.urls.path` and/or :func:`~django.urls.re_path` instances.
|
2017-09-13 15:24:12 -04:00
|
|
|
:arg app_namespace: Application namespace for the URL entries being included
|
2018-02-12 09:09:46 -05:00
|
|
|
:type app_namespace: str
|
2017-09-13 15:24:12 -04:00
|
|
|
|
|
|
|
See :ref:`including-other-urlconfs` and :ref:`namespaces-and-include`.
|
|
|
|
|
2016-10-20 19:29:04 +02:00
|
|
|
``register_converter()``
|
|
|
|
========================
|
|
|
|
|
|
|
|
.. function:: register_converter(converter, type_name)
|
|
|
|
|
|
|
|
The function for registering a converter for use in :func:`~django.urls.path()`
|
|
|
|
``route``\s.
|
|
|
|
|
|
|
|
The ``converter`` argument is a converter class, and ``type_name`` is the
|
|
|
|
converter name to use in path patterns. See
|
|
|
|
:ref:`registering-custom-path-converters` for an example.
|
|
|
|
|
2017-09-13 15:24:12 -04:00
|
|
|
==================================================
|
|
|
|
``django.conf.urls`` functions for use in URLconfs
|
|
|
|
==================================================
|
2012-09-27 19:16:49 -03:00
|
|
|
|
|
|
|
.. module:: django.conf.urls
|
|
|
|
|
2016-01-24 22:26:11 +01:00
|
|
|
``static()``
|
|
|
|
============
|
2013-03-07 14:15:39 -05:00
|
|
|
|
2014-08-12 10:54:42 -04:00
|
|
|
.. function:: static.static(prefix, view=django.views.static.serve, **kwargs)
|
2013-03-07 14:15:39 -05:00
|
|
|
|
|
|
|
Helper function to return a URL pattern for serving files in debug mode::
|
|
|
|
|
|
|
|
from django.conf import settings
|
|
|
|
from django.conf.urls.static import static
|
|
|
|
|
2014-04-01 20:46:34 -04:00
|
|
|
urlpatterns = [
|
2013-03-07 14:15:39 -05:00
|
|
|
# ... the rest of your URLconf goes here ...
|
2014-04-01 20:46:34 -04:00
|
|
|
] + static(settings.MEDIA_URL, document_root=settings.MEDIA_ROOT)
|
2013-03-07 14:15:39 -05:00
|
|
|
|
2016-01-24 22:26:11 +01:00
|
|
|
``handler400``
|
|
|
|
==============
|
2013-09-22 11:21:09 -03:00
|
|
|
|
|
|
|
.. data:: handler400
|
|
|
|
|
|
|
|
A callable, or a string representing the full Python import path to the view
|
|
|
|
that should be called if the HTTP client has sent a request that caused an error
|
|
|
|
condition and a response with a status code of 400.
|
|
|
|
|
2017-01-27 23:13:40 +02:00
|
|
|
By default, this is :func:`django.views.defaults.bad_request`. If you
|
2018-07-31 15:59:38 +01:00
|
|
|
implement a custom view, be sure it accepts ``request`` and ``exception``
|
|
|
|
arguments and returns an :class:`~django.http.HttpResponseBadRequest`.
|
2013-09-22 11:21:09 -03:00
|
|
|
|
2016-01-24 22:26:11 +01:00
|
|
|
``handler403``
|
|
|
|
==============
|
2012-09-27 19:16:49 -03:00
|
|
|
|
|
|
|
.. data:: handler403
|
|
|
|
|
|
|
|
A callable, or a string representing the full Python import path to the view
|
|
|
|
that should be called if the user doesn't have the permissions required to
|
|
|
|
access a resource.
|
|
|
|
|
2017-01-27 23:13:40 +02:00
|
|
|
By default, this is :func:`django.views.defaults.permission_denied`. If you
|
2018-07-31 15:59:38 +01:00
|
|
|
implement a custom view, be sure it accepts ``request`` and ``exception``
|
|
|
|
arguments and returns an :class:`~django.http.HttpResponseForbidden`.
|
2012-09-27 19:16:49 -03:00
|
|
|
|
2016-01-24 22:26:11 +01:00
|
|
|
``handler404``
|
|
|
|
==============
|
2012-09-27 19:16:49 -03:00
|
|
|
|
|
|
|
.. data:: handler404
|
|
|
|
|
|
|
|
A callable, or a string representing the full Python import path to the view
|
|
|
|
that should be called if none of the URL patterns match.
|
|
|
|
|
2017-01-27 23:13:40 +02:00
|
|
|
By default, this is :func:`django.views.defaults.page_not_found`. If you
|
2018-07-31 15:59:38 +01:00
|
|
|
implement a custom view, be sure it accepts ``request`` and ``exception``
|
|
|
|
arguments and returns an :class:`~django.http.HttpResponseNotFound`.
|
2012-09-27 19:16:49 -03:00
|
|
|
|
2016-01-24 22:26:11 +01:00
|
|
|
``handler500``
|
|
|
|
==============
|
2012-09-27 19:16:49 -03:00
|
|
|
|
|
|
|
.. data:: handler500
|
|
|
|
|
|
|
|
A callable, or a string representing the full Python import path to the view
|
|
|
|
that should be called in case of server errors. Server errors happen when you
|
|
|
|
have runtime errors in view code.
|
|
|
|
|
2017-01-27 23:13:40 +02:00
|
|
|
By default, this is :func:`django.views.defaults.server_error`. If you
|
2019-11-05 15:27:09 -05:00
|
|
|
implement a custom view, be sure it accepts a ``request`` argument and returns
|
|
|
|
an :class:`~django.http.HttpResponseServerError`.
|