我正在使用djangoappengine。当我尝试创建一个新用户、验证该用户并将其登录时,我会收到以下错误AttributeError: 'AnonymousUser' object has no attribute 'backend'
。
我的代码很简单,看起来像:
user = User.objects.create_user(username, username, password)
user.set_password(password)
user.save()
user = django.contrib.auth.authenticate(username=username, password=password)
django.contrib.auth.login(request, user)
我只在生产中遇到以下错误,而且只是偶尔出现:
web req_create: 'AnonymousUser' object has no attribute 'backend'
Traceback (most recent call last):
File "/base/data/home/apps/s~XXXXX/1.356802202883392818/XXXX/XXX.py", line 332, in req_create
login(request, user)
File "/base/data/home/apps/s~XXXXX/1.356802202883392818/django/contrib/auth/__init__.py", line 82, in login
request.session[BACKEND_SESSION_KEY] = user.backend
AttributeError: 'AnonymousUser' object has no attribute 'backend'
我不确定,但我有一种不好的感觉,这种异常是由于高复制数据存储及其最终的一致性造成的。我认为authenticate()
保存用户值,login()
执行查询,但用户值尚未传播到HRDS中。有人能证实这是真的吗?如果是的话,该如何解决?
保存用户时,它不会自动激活。请查看AnonymousUser的链接,该链接说明您的用户如何成为AnonymousUser
。
因此,您必须设置所有可能使您的用户成为AnonymousUser
的项目。在进行身份验证之前,请检查user.is_anonymous()
。
也有同样的问题。但问题是用户名太长,被截断为30个字符。在这里找到答案:
Django注册表';匿名用户';对象没有属性';后端';
当用户未通过身份验证时会发生这种情况。请确保您使用相同的字段登录后端。。。例如,我使用电子邮件登录(使用电子邮件和密码的后端),因此
django.contrib.auth.authenticate(username=username, password=password)
如果对我来说
django.contrib.auth.authenticate(username=email, password=password)
后端在这里:http://www.micahcarrick.com/django-email-authentication.html
如果您在数据库中使用复制,并且在向主数据库/默认数据库写入时恰好从读取副本读取,那么如果存在复制滞后也可能导致这种情况。你会写信给大师而authenticate将尝试从读取副本中读取,导致找不到用户。
解决方案是将路由器设置为使用默认数据库进行用户查询。