Django多个用户登录和注销

时间:2019-04-04 14:58:53

标签: django django-authentication

两个相同类型的用户登录。当其中一个用户更改选项卡时,现在该用户是最后登录的用户({{user.username}}更改)。

对我来说,更主要的问题是,其中一个注销后,另一个自动注销。基本上没有两个用户,一次只有一个,即最后登录的用户。
另外,所有视图都是@login_required。

@login_required
def user_logout(request):
    logout(request)
    return HttpResponseRedirect(reverse('login'))


def user_login(request):
    if request.method == 'POST':
        username = request.POST.get('username')
        password = request.POST.get('password')
        user = authenticate(username=username, password=password)
        if user:
            login(request, user)
            return HttpResponseRedirect(reverse('success_page'))
        else:
            return render(request, 'login.html')
    else:
        return render(request, 'login.html')

在settings.py中:

SESSION_COOKIE_AGE = 24*60*60
LOGIN_URL = '/login/'

我的基本用户表单:

from django.contrib.auth.forms import UserCreationForm
from django.contrib.auth.models import User

class SignUpForm(UserCreationForm):
    email = forms.EmailField(max_length=254, help_text='Required. Inform a valid email address.')

    class Meta:
        model = User
        fields = ('username', 'email', 'password1', 'password2', )

我的问题是,如何在Django应用程序中同时登录多个用户。

1 个答案:

答案 0 :(得分:1)

Django使用会话来管理用户。基本上,当用户登录Django Webiste时,Django后端会在用户浏览器中放置一个cookie,该cookie将浏览器标识为刚刚登录的用户。Django(以及基本上所有其他框架/实现)将仅允许这些用户之一每个会话的Cookie。

因此,如果您想以某种方式再次登录而不注销,它将简单地覆盖当前用户cookie并有效注销以前的用户。