我已在多个页面中创建登录页面强制登录。现在我需要在成功登录后重定向回到上一页。
当我强制@login_required(login_url='/login/')
登录时。它在查询字符串中包含next
参数。
我尝试使用redirect_to = request.REQUEST.get('next', '')
抓住它并将其发送给重定向return HttpResponseRedirect(redirect_to)
,但无效。
view.py
def login(request):
def errorHandle(error):
form = LoginForm()
return render_to_response('login/login.html', {
'error' : error,
'form' : form,
})
if request.method == 'POST': # If the form has been submitted...
form = LoginForm(request.POST) # A form bound to the POST data
if form.is_valid(): # All validation rules pass
username = request.POST['username']
password = request.POST['password']
redirect_to = request.REQUEST.get('next', '')
user = authenticate(username=username, password=password)
if user is not None:
if user.is_active:
# Redirect to a success page.
auth_login(request, user)
return HttpResponseRedirect(redirect_to)
# return render_to_response('login/logged_in.html', {
# 'username': username,
# })
else:
# Return a 'disabled account' error message
error = u'Account Disabled'
return errorHandle(error)
else:
# Return an 'invalid login' error message.
error = u'Invalid Login'
return errorHandle(error)
else:
error = u'Form is Invalid'
return errorHandle(error)
else:
form = LoginForm() # An unbound form
return render_to_response('login/login.html', {
'form': form,
})
模板
<div id="login_form">
<form action="." method="post">
{{ form.as_p }}
<input type="submit" value="Login">
</form>
</div>
编辑 - 我发现了这个问题。这是我的模板的问题。下面的表格工作正常。
<form action="" method="post">
<label for="username">User name:</label>
<input type="text" name="username" value="" id="username">
<label for="password">Password:</label>
<input type="password" name="password" value="" id="password">
<input type="submit" value="Login" id="button"/>
<input type="hidden" name="next" value="{{ next|escape }}" />
</form>
答案 0 :(得分:3)
您可以将其添加到表单中:
<input type="hidden" value="{% if request.REQUEST.next %}{{ request.REQUEST.next }}{% else %}{% if request.META.HTTP_REFERER %}{{ request.META.HTTP_REFERER }}{% else %}/{% endif %}{% endif %}" name="next" />
以下是解决的案例:
请注意,这也适用于外部登录视图,您应该使用它。
作为一个礼物,这是我的注销模板的一部分,它将用户重定向到他退出之前的页面。
{% block body %}
<p>{% trans "You've been logged out." %}</p>
{% if '/account/logout/' not in request.META.HTTP_REFERER %}
<p>
{% trans 'You will be redirected in a second' %}
</p>
{% endif %}
{% endblock %}
{% block extra_body %}
{% if '/account/logout/' not in request.META.HTTP_REFERER %}
<script type="text/javascript">
document.location.href = '{{ request.META.HTTP_REFERER }}';
</script>
{% endif %}
{% endblock %}
我要感谢聘请我sports pick, tipster social network的伟大创业公司因为他们允许我分享代码和1)用我的一些时间来帮助别人。但我链接它的真正原因是你可以测试它。如果这段代码对你不起作用,那么你就会有另一个问题。