登录后重定向回上一页(Django)

时间:2012-04-03 07:46:11

标签: python django

我已在多个页面中创建登录页面强制登录。现在我需要在成功登录后重定向回到上一页。

当我强制@login_required(login_url='/login/')登录时。它在查询字符串中包含next参数。

enter image description here

我尝试使用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>

1 个答案:

答案 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" />

以下是解决的案例:

  1. 如果用户来自login_required视图:next由login_required设置
  2. 如果用户来自登录表单(即身份验证未通过):next =之前设置的下一个值
  3. 如果用户来自非login_required视图:next = referer url
  4. 如果用户直接打开登录页面:next = /
  5. 请注意,这也适用于外部登录视图,您应该使用它。

    作为一个礼物,这是我的注销模板的一部分,它将用户重定向到他退出之前的页面。

    {% 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)用我的一些时间来帮助别人。但我链接它的真正原因是你可以测试它。如果这段代码对你不起作用,那么你就会有另一个问题。