查询字符串将隐式传递到任何视图,而无需编写任何特殊代码。
您要做的就是确保将
next密钥从实际的登录表单(在您的情况下,这是在中呈现的表单
/accounts/login/)传递到
/accounts/auth视图。
为此,您需要确保
django.core.context_processors.request在设置中启用了请求模板上下文处理器()。为此,首先需要导入的默认值
TEMPLATE_CONTEXT_PROCESSORS,然后在中将请求处理器添加到其中
settings.py,如下所示:
from django.conf import global_settingsTEMPLATE_CONTEXT_PROCESSORS = global_settings.TEMPLATE_CONTEXT_PROCESSORS + ( "django.core.context_processors.request",)
然后以以下形式:
<form method="POST" action="/accounts/auth"> {% csrf_token %} <input type="hidden" name="next" value="{{ request.GET.next }}" /> {{ login_form }} <input type="submit"></form>
现在,在您
/accounts/auth看来:
def foo(request): if request.method == 'POST': # .. authenticate your user # redirect to the value of next if it is entered, otherwise # to /accounts/profile/ return redirect(request.POST.get('next','/accounts/profile/'))
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)