为什么我无法注销django用户身份验证?

问题描述:

我正在使用django.contrib.auth用户管理系统。为什么我无法注销django用户身份验证?

所以我就注册/插入到用户表/模型,并将其从django.contrib.auth.views.login,这样我就可以登录登录。

但是,我不能使用Django .contrib.auth.views.logout注销

我有我的模板

<h1>My Account</h1> 
<strong> Welcome, {{ name|capfirst }}!</strong> 
<br /><br /> 
<ul> 
    <li> 
     {% if user.is_authenticated %} 
      <a href="{% url django.contrib.auth.views.logout %}">Logout</a> 
     {% else %} 
      <a href="{% url register %}">Sign Up</a> 
    </li> 
    <li> 
      <a href="{% url django.contrib.auth.views.login %}">Login</a> 
     {% endif %} 
    </li> 
</ul> 

不过,我总是得到的名称和注销链接,因为我从来没有真正当我点击退出按钮退出

这是我为这个urls.py部分:

urlpatterns += patterns('django.contrib.auth.views', 
    url(r'^login/$', 'login', { 'template_name': 'registration/login.html', 'SSL': settings.ENABLE_SSL }, 'login'), 
    url(r'^my_account/$', 'logout', { 'template_name': 'registration/my_account.html', 'SSL': settings.ENABLE_SSL }, 'logout'), 
) 

我在做什么错? 注:我也是通过的Apache2运行Django与mod_wsgi的

谢谢!

新增信息:

不知道这是否帮助,但我在HTML印刷request.session.items并得到

[('_auth_user_backend', 'django.contrib.auth.backends.ModelBackend'), ('_auth_user_id', 9L)] 

当我登录了,也经过我点击退出按钮( django.contrib.auth.views.logout)

而且,我创建:

from django.contrib.auth import logout 
def logout_view(request): 
    request.session.items = [] 
    request.session.modified = True 
    logout(request) 

和链接,为第二注销链接/按钮,我没有注销和request.session.items保持不变如上点击链接

我觉得我在收盘后:

在我的看法功能之一我所做的:

request.session["fav_color"] = "blue" 
request.session.modified = True 

,然后在HTML打印{{request.session.items}}这给了我

[('_auth_user_backend', 'django.contrib.auth.backends.ModelBackend'), ('_auth_user_id', 9L)] 

,并没有( 'fav_color', '蓝')元组。我又做错了什么,还是证明我的request.session列表没有被修改?

ķ想通了:

url(r'^my_account/$', 'logout', { 'template_name': 'registration/my_account.html', 'SSL': settings.ENABLE_SSL }, 'logout'), 

应该

url(r'^logout/$', 'logout', { 'template_name': 'registration/my_account.html', 'SSL': settings.ENABLE_SSL }, 'logout'), 
+0

这看起来对我来说是正确的。您可能想要安装django调试工具栏,并查看它说的用户对象是什么。这可以帮助您确定用户变量是否正确等。 – Hutch 2011-06-14 20:05:22

+0

添加了一些额外的信息,也许这可能有助于确定问题是什么? – Derek 2011-06-14 20:24:40

我认为urls.py会是这样的(login and logout views do not accept SSL parameter):

from django.core.urlresolvers import reverse 
urlpatterns += patterns('django.contrib.auth.views', 
     url(r'^login/$', 'login', { 'template_name': 'registration/login.html'}, name='login'), 
     url(r'^logout/$', 'logout', { 'template_name': 'registration/my_account.html', 'next_page':reverse('index') }, name='logout'), 
) 

而且在模板:

<h1>My Account</h1> 
<strong> Welcome, {{ name|capfirst }}!</strong> 
<br /><br /> 
<ul> 
    <li> 
     {% if user.is_authenticated %} 
      <a href="{% url logout %}">Logout</a> 
     {% else %} 
      <a href="{% url register %}">Sign Up</a> 
    </li> 
    <li> 
      <a href="{% url login %}">Login</a> 
     {% endif %} 
    </li> 
</ul> 

您需要使用网址指向该视图注销视图。没有什么必须在模板上,只需在该注销视图中使用django.contrib.auth.logout()。在新的django服务器上,您可以进行eaisly注销,但您需要在视图中执行此操作,而不是模板。下面是来自Django的一本书的摘录:

这个例子说明了如何将一个视图函数中使用这两种身份验证()和login():

from django.contrib import auth 

def login_view(request): 
    username = request.POST.get('username', '') 
    password = request.POST.get('password', '') 
    user = auth.authenticate(username=username, password=password) 
    if user is not None and user.is_active: 
     # Correct password, and the user is marked "active" 
     auth.login(request, user) 
     # Redirect to a success page. 
     return HttpResponseRedirect("/account/loggedin/") 
    else: 
     # Show an error page 
     return HttpResponseRedirect("/account/invalid/") 

要注销用户,请使用django.contrib中.auth.logout()在您的视图中。它带有一个HttpRequest对象,并没有返回值:

from django.contrib import auth 

def logout_view(request): 
    auth.logout(request) 
    # Redirect to a success page. 
    return HttpResponseRedirect("/account/loggedout/") 

参考Django的书都http://www.djangobook.com/en/2.0/chapter14/方面,我从这本书里学到的一切。

我遇到过这个问题,这是一个愚蠢的头痛。这是我强制登出的方式。我保存logout(request)(希望)触发用户退出信号:

def logout_view(request): 

    logout(request) 
    request.session.flush() 
    request.user = AnonymousUser 

    return HttpResponseRedirect('accounts/loggedout/') 

您不必写一个视图,你可以做:

(r'^accounts/logout/$', 'django.contrib.auth.views.logout',{'next_page': '/accounts/login'})

更多信息:https://docs.djangoproject.com/en/dev/topics/auth/default/#django.contrib.auth.views.logout