我想防止同一个用户帐户在我的应用程序中具有多个活动会话,并遵循此问题的答案。
我将其实现到我的models.py:
from django.conf import settings
from django.db import models
from django.contrib.sessions.models import Session
class UserSession(models.Model):
user = models.ForeignKey(settings.AUTH_USER_MODEL, on_delete=models.CASCADE)
session = models.OneToOneField(Session, on_delete=models.CASCADE)
from django.contrib.auth import user_logged_in
from django.dispatch.dispatcher import receiver
@receiver(user_logged_in)
def remove_other_sessions(sender, user, request, **kwargs):
# remove other sessions
Session.objects.filter(usersession__user=user).delete()
# save current session
request.session.save()
# create a link from the user to the current session (for later removal)
UserSession.objects.get_or_create(
user=user,
session=Session.objects.get(pk=request.session.session_key)
)
它工作得很好,但是,我注意到了一种奇怪的行为。
如果我使用一个帐户登录,然后打开一个隐身窗口并使用相同的凭据登录,第一个将被注销(这正是我想要的)。
但是,如果我使用帐户登录,然后关闭浏览器,下次我想登录时,我会在行中收到错误消息:
# save current session
request.session.save()
具有以下追溯(没有太多信息..):
更新错误在 /
未提供异常消息
控制台日志显示错误来自
django.contrib.sessions.backends.base.UpdateError
在此之后,如果我刷新页面,则可以成功登录。
对可能发生的事情的任何见解?
PIPIONE
慕无忌1623718
相关分类