我很好奇这段代码实际上是如何工作的。特别是 request.__class__.user = LazyUser()
是什么?做与 setattr(request, user, LazyUser())
相反的事情。抱歉,如果这是一个无知的问题,我想知道,因为我将实现一个类似的中间件,为请求添加一个属性。
这是代码,当然当你调用 request.user
时您将返回某种用户对象。
class LazyUser(object):
def __get__(self, request, obj_type=None):
if not hasattr(request, '_cached_user'):
from django.contrib.auth import get_user
request._cached_user = get_user(request)
return request._cached_user
class AuthenticationMiddleware(object):
def process_request(self, request):
assert hasattr(request, 'session'), "The Django authentication middleware requires session middleware to be installed. Edit your MIDDLEWARE_CLASSES setting to insert 'django.contrib.sessions.middleware.SessionMiddleware'."
request.__class__.user = LazyUser()
return None
更新:稍微阅读一下,我就明白 __get__
是如何工作的。位有效,所以我的问题归结为为什么这样做与使用 setattr()
正如我上面提到的。为什么要添加user
作为对象的属性与实例的属性是个好主意吗?
最佳答案
在这种情况下,由于 LazyUser() 是一个类,它可以确定请求对象是否已经检查过,以确保已查询到用户,这才是真正的魔力,它只需要查询用户的数据库每个 session 一次。作为一个属性,它是一个通用操作,将应用于请求的所有实例。所述对象的所有实例的属性都是相同的。这只是使 user 属性成为 LazyUser 的实例,只允许内存中存在一个实例(iirc 这部分,其他人应该能够澄清这一点)。
关于python - Django LazyUser 代码如何工作?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5644527/