django.contrib.auth.context_processors.auth는 {{ user }}
템플릿 컨텍스트 변수를 request.user 또는 AnonymousUser로 설정합니다.
def auth(request):
"""
Returns context variables required by apps that use Django's authentication
system.
If there is no 'user' attribute in the request, uses AnonymousUser (from
django.contrib.auth).
"""
# If we access request.user, request.session is accessed, which results in
# 'Vary: Cookie' being sent in every request that uses this context
# processor, which can easily be every request on a site if
# TEMPLATE_CONTEXT_PROCESSORS has this context processor added. This kills
# the ability to cache. So, we carefully ensure these attributes are lazy.
# We don't use django.utils.functional.lazy() for User, because that
# requires knowing the class of the object we want to proxy, which could
# break with custom auth backends. LazyObject is a less complete but more
# flexible solution that is a good enough wrapper for 'User'.
def get_user():
if hasattr(request, 'user'):
return request.user
else:
from django.contrib.auth.models import AnonymousUser
return AnonymousUser()
return {
'user': SimpleLazyObject(get_user),
'messages': messages.get_messages(request),
'perms': lazy(lambda: PermWrapper(get_user()), PermWrapper)(),
}
당신은 setting context_object_name하여 문제를 해결할 수 있습니다 : 그래서, 그것은 당신의 DetailView에 의해 생성 된 {{ user }}
컨텍스트 변수보다 우선합니다.
url(
r'^users/(?P<pk>\d+)/$',
DetailView.as_view(
model = User,
template_name = 'doors/users/detail.html',
context_object_name = 'user_object'
),
name = 'users_detail'
)
파고 깊은, get_context_object_name() 설명서를 읽어 예를 들어, 다음은 DetailView의 사용자로 설정 {{ user_object }}
컨텍스트 변수를 가능하게 할 것이다.
100 % 확신 할 수는 없지만 다른 일반적인보기가 있었으며 변수는 모델의 이름입니다. 예를 들어'ListView'에서'model = Poll'을했다면 변수는'poll_list'가됩니다. 'DetailView '와 같은 것은 변수 이름'poll'을줍니다. 아마도 이것은 Django v1.4의 새로운 기능일까요? – hobbes3
당신이 맞습니다, 위의 답변을 수정했습니다. 의견을 보내 주셔서 감사합니다 ! – jpic