[python] Django에서 사용자가 특정 그룹에 있는지 어떻게 확인합니까?
Django의 관리 사이트에서 사용자 정의 그룹을 만들었습니다.
내 코드에서 사용자가이 그룹에 있는지 확인하고 싶습니다. 어떻게합니까?
답변
의 groups
속성을 통해 그룹에 간단히 액세스 할 수 있습니다 User
.
from django.contrib.auth.models import User, Group
group = Group(name = "Editor")
group.save() # save this new group for this example
user = User.objects.get(pk = 1) # assuming, there is one initial user
user.groups.add(group) # user is now in the "Editor" group
그런 user.groups.all()
다음를 반환합니다 [<Group: Editor>]
.
또는보다 직접적으로 다음을 통해 사용자가 그룹에 있는지 확인할 수 있습니다.
if django_user.groups.filter(name = groupname).exists():
...
주 groupname
수 도 실제 장고 그룹 개체 수.
답변
귀하의 사용자 개체가 연결되어 그룹의 스루 객체 ManyToMany의 관계.
필터 메소드를 user.groups에 적용 할 수 있습니다 .
따라서 주어진 사용자가 특정 그룹 (예 : “회원”)에 있는지 확인하려면 다음과 같이하십시오.
def is_member(user):
return user.groups.filter(name='Member').exists()
지정된 사용자가 둘 이상의 지정된 그룹에 속하는지 확인하려면 __in 연산자를 다음과 같이 사용하십시오 .
def is_in_multiple_groups(user):
return user.groups.filter(name__in=['group1', 'group2']).exists()
이러한 함수는 @user_passes_test 데코레이터 와 함께 사용 하여 뷰에 대한 액세스를 관리 할 수 있습니다.
from django.contrib.auth.decorators import login_required, user_passes_test
@login_required
@user_passes_test(is_member) # or @user_passes_test(is_in_multiple_groups)
def myview(request):
# Do your processing
이 도움을 바랍니다
답변
그룹에 속한 사용자 목록이 필요한 경우 다음을 수행하십시오.
from django.contrib.auth.models import Group
users_in_group = Group.objects.get(name="group name").user_set.all()
그런 다음 확인
if user in users_in_group:
# do something
사용자가 그룹에 있는지 확인합니다.
답변
사이트에서 사용자 인스턴스가 필요하지 않은 경우 (내가했던 것처럼)
User.objects.filter(pk=userId, groups__name='Editor').exists()
이것은 데이터베이스에 단 하나의 요청을 생성하고 부울을 리턴합니다.
답변
사용자가 특정 그룹에 속하는지 여부는 다음을 사용하여 django 템플릿에서 확인할 수 있습니다.
{% if group in request.user.groups.all %}
"some action"
{% endif %}
답변
한 줄만 있으면됩니다.
from django.contrib.auth.decorators import user_passes_test
@user_passes_test(lambda u: u.groups.filter(name='companyGroup').exists())
def you_view():
return HttpResponse("Since you're logged in, you can see this text!")
답변
사용자 그룹이 사전 정의 된 그룹 목록에 속하는지 확인하려는 경우 :
def is_allowed(user):
allowed_group = set(['admin', 'lead', 'manager'])
usr = User.objects.get(username=user)
groups = [ x.name for x in usr.groups.all()]
if allowed_group.intersection(set(groups)):
return True
return False