2017-09-14 03:24:12 +08:00
|
|
|
=============================================
|
|
|
|
``django.urls`` functions for use in URLconfs
|
|
|
|
=============================================
|
|
|
|
|
|
|
|
.. module:: django.urls.conf
|
|
|
|
:synopsis: Functions for use in URLconfs.
|
|
|
|
|
|
|
|
.. currentmodule:: django.conf.urls
|
|
|
|
|
|
|
|
``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
|
|
|
|
:type namespace: string
|
|
|
|
:arg pattern_list: Iterable of :func:`django.conf.urls.url` instances
|
|
|
|
:arg app_namespace: Application namespace for the URL entries being included
|
|
|
|
:type app_namespace: string
|
|
|
|
:arg instance_namespace: Instance namespace for the URL entries being included
|
|
|
|
:type instance_namespace: string
|
|
|
|
|
|
|
|
See :ref:`including-other-urlconfs` and :ref:`namespaces-and-include`.
|
|
|
|
|
|
|
|
.. versionchanged:: 2.0
|
|
|
|
|
|
|
|
In older versions, this function is located in ``django.conf.urls``. The
|
|
|
|
old location still works for backwards compatibility.
|
|
|
|
|
|
|
|
==================================================
|
|
|
|
``django.conf.urls`` functions for use in URLconfs
|
|
|
|
==================================================
|
2012-09-28 06:16:49 +08:00
|
|
|
|
|
|
|
.. module:: django.conf.urls
|
|
|
|
|
2016-01-25 05:26:11 +08:00
|
|
|
``static()``
|
|
|
|
============
|
2013-03-08 03:15:39 +08:00
|
|
|
|
2014-08-12 22:54:42 +08:00
|
|
|
.. function:: static.static(prefix, view=django.views.static.serve, **kwargs)
|
2013-03-08 03:15:39 +08: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-02 08:46:34 +08:00
|
|
|
urlpatterns = [
|
2013-03-08 03:15:39 +08:00
|
|
|
# ... the rest of your URLconf goes here ...
|
2014-04-02 08:46:34 +08:00
|
|
|
] + static(settings.MEDIA_URL, document_root=settings.MEDIA_ROOT)
|
2013-03-08 03:15:39 +08:00
|
|
|
|
2016-01-25 05:26:11 +08:00
|
|
|
``url()``
|
|
|
|
=========
|
2012-09-28 06:16:49 +08:00
|
|
|
|
2015-08-17 23:07:03 +08:00
|
|
|
.. function:: url(regex, view, kwargs=None, name=None)
|
2012-09-28 06:16:49 +08:00
|
|
|
|
2014-04-02 08:46:34 +08:00
|
|
|
``urlpatterns`` should be a list of ``url()`` instances. For example::
|
2012-09-28 06:16:49 +08:00
|
|
|
|
2016-06-20 17:07:59 +08:00
|
|
|
from django.conf.urls import include, url
|
|
|
|
|
2014-04-02 08:46:34 +08:00
|
|
|
urlpatterns = [
|
2016-06-20 17:07:59 +08:00
|
|
|
url(r'^index/$', index_view, name='main-view'),
|
|
|
|
url(r'^weblog/', include('blog.urls')),
|
2012-09-28 06:16:49 +08:00
|
|
|
...
|
2014-04-02 08:46:34 +08:00
|
|
|
]
|
2012-09-28 06:16:49 +08:00
|
|
|
|
2016-12-23 08:16:26 +08:00
|
|
|
The ``regex`` parameter should be a string or
|
2017-01-27 03:58:33 +08:00
|
|
|
:func:`~django.utils.translation.gettext_lazy()` (see
|
2016-12-23 08:16:26 +08:00
|
|
|
: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.
|
|
|
|
|
2016-06-20 17:07:59 +08:00
|
|
|
The ``view`` parameter 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:`include`.
|
|
|
|
|
2014-03-26 05:06:54 +08:00
|
|
|
The ``kwargs`` parameter allows you to pass additional arguments to the view
|
|
|
|
function or method. See :ref:`views-extra-options` for an example.
|
|
|
|
|
2012-09-28 06:16:49 +08:00
|
|
|
See :ref:`Naming URL patterns <naming-url-patterns>` for why the ``name``
|
|
|
|
parameter is useful.
|
|
|
|
|
2016-01-25 05:26:11 +08:00
|
|
|
``handler400``
|
|
|
|
==============
|
2013-09-22 22:21:09 +08: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-28 05:13:40 +08:00
|
|
|
By default, this is :func:`django.views.defaults.bad_request`. If you
|
2016-01-05 09:11:20 +08:00
|
|
|
implement a custom view, be sure it returns an
|
|
|
|
:class:`~django.http.HttpResponseBadRequest`.
|
2013-09-22 22:21:09 +08:00
|
|
|
|
2016-01-25 05:26:11 +08:00
|
|
|
``handler403``
|
|
|
|
==============
|
2012-09-28 06:16:49 +08: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-28 05:13:40 +08:00
|
|
|
By default, this is :func:`django.views.defaults.permission_denied`. If you
|
2016-01-05 09:11:20 +08:00
|
|
|
implement a custom view, be sure it returns an
|
|
|
|
:class:`~django.http.HttpResponseForbidden`.
|
2012-09-28 06:16:49 +08:00
|
|
|
|
2016-01-25 05:26:11 +08:00
|
|
|
``handler404``
|
|
|
|
==============
|
2012-09-28 06:16:49 +08: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-28 05:13:40 +08:00
|
|
|
By default, this is :func:`django.views.defaults.page_not_found`. If you
|
2016-01-05 09:11:20 +08:00
|
|
|
implement a custom view, be sure it returns an
|
|
|
|
:class:`~django.http.HttpResponseNotFound`.
|
2012-09-28 06:16:49 +08:00
|
|
|
|
2016-01-25 05:26:11 +08:00
|
|
|
``handler500``
|
|
|
|
==============
|
2012-09-28 06:16:49 +08: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-28 05:13:40 +08:00
|
|
|
By default, this is :func:`django.views.defaults.server_error`. If you
|
2016-01-05 09:11:20 +08:00
|
|
|
implement a custom view, be sure it returns an
|
|
|
|
:class:`~django.http.HttpResponseServerError`.
|