Skip to content


Subversion checkout URL

You can clone with
Download ZIP
Browse files

[1.0.X] Documented how to handle '%' characters in redirect_to() URL …


(even in the absence of keyword arguments). Fixed #9773.

Backport of r9626 from trunk.

git-svn-id: bcc190cf-cafb-0310-a4f2-bffc1f526a37
  • Loading branch information...
1 parent 2e4336b commit 4aaa15e81269e4e44247d92f3a8759024653d6d1 @malcolmt malcolmt committed
Showing with 12 additions and 1 deletion.
  1. +12 −1 docs/ref/generic-views.txt
13 docs/ref/generic-views.txt
@@ -120,7 +120,10 @@ variable ``{{ }}`` that is set to ``15``.
Redirects to a given URL.
The given URL may contain dictionary-style string formatting, which will be
-interpolated against the parameters captured in the URL.
+interpolated against the parameters captured in the URL. Because keyword
+interpolation is *always* done (even if no arguments are passed in), any ``"%"``
+characters in the URL must be written as ``"%%"`` so that Python will convert
+them to a single percent sign on output.
If the given URL is ``None``, Django will return an ``HttpResponseGone`` (410).
@@ -143,6 +146,14 @@ This example returns a 410 HTTP error for requests to ``/bar/``::
('^bar/$', 'redirect_to', {'url': None}),
+This example shows how ``"%"`` characters must be written in the URL in order
+to avoid confusion with Python's string formatting markers. If the redirect
+string is written as ``"%7Ejacob/"`` (with only a single ``%``), an exception would be raised::
+ urlpatterns = patterns('django.views.generic.simple',
+ ('^bar/$', 'redirect_to', {'url': '%%7Ejacob.'}),
+ )
Date-based generic views

0 comments on commit 4aaa15e

Please sign in to comment.
Something went wrong with that request. Please try again.