>백엔드 개발 >파이썬 튜토리얼 >Django 사용자 인증 시스템 (1) User 객체

Django 사용자 인증 시스템 (1) User 객체

黄舟
黄舟원래의
2016-12-23 17:41:071312검색

사용자 개체

사용자 개체는 인증 시스템의 핵심입니다. 사용자 개체는 일반적으로 웹 사이트 사용자를 나타내고 액세스 제어, 등록된 사용자, 작성자와 콘텐츠 연결 등을 지원하는 데 사용됩니다. Django 인증 프레임워크에는 사용자 클래스가 하나만 있습니다. 예를 들어 슈퍼유저('superusers') 또는 ('staff') 사용자는 서로 다른 속성이 설정된 동일한 사용자 개체입니다.

기본 필드 필드

사용자 이름

사용자 이름, 필수 필드입니다. 30자 이하이며 _, @, +, - 문자를 포함할 수 있습니다.

first_name
선택사항. 30자 이하.


선택 사항. 30자 이하.

이메일
이메일, 선택사항. 이메일 주소.

passWord
비밀번호, 필수입니다. Django는 비밀번호를 일반 텍스트로 저장하지 않고 대신 해시를 저장합니다.

그룹
사용자 그룹. 그룹

user_permissions
사용자 권한에 대한 다대다 관계. Permission

에 대한 다대다 관계 groups = models.ManyToManyField(Group, verbose_name=_('groups'),
공백=True, help_text=_('이 사용자가 속한 그룹입니다. 사용자는 '
'자신의 그룹'),
''
'자신의 그룹') 각각에 부여된 모든 권한을 얻습니다.
관련_이름="user_set", 관련_ 쿼리_이름="사용자 ")
user_permissions = models.ManyToManyField( Permission,
verbose_name=_('사용자 권한'), 공백=True,
help_text=_('이 사용자에 대한 특정 권한.'),
관련_name="user_set", 관련_query_name="user" )


is_staff

부울. 사용자가 관리자 관리 인터페이스에 액세스할 수 있는지 여부를 결정합니다. 기본값은 거짓입니다.


is_active

부울입니다. 사용자가 활성 상태인지 여부, 기본값은 True입니다. 일반적으로 사용자는 삭제되지 않지만 사용자의 is_active는 False로 설정됩니다.


is_superuser

부울입니다. 기본값은 거짓입니다. True로 설정하면 사용자는 모든 권한을 얻습니다.


def has_perm(self, perm, obj=None):
"""
사용자에게 지정된 권한이 있는 경우 True를 반환합니다. 이 메소드
는 사용 가능한 모든 인증 백엔드를 쿼리하지만 반환
백엔드가 True를 반환하면 즉시 단일
인증 백엔드에서 권한을 가진 사용자는 일반적으로 객체가 PROvided인 경우 이 특정 객체에 대한 권한을 확인합니다.
"""

               # 활성 수퍼유저는 모든 권한을 갖습니다. > Return _user_has_perm(self, perm, obj)


last_login

마지막 로그인 시간은 datetime 객체입니다. , 기본값은 해당 시간의 시간입니다.

user.last_login = timezone.now()

date_joined

사용자 생성 시간

방법


is_anonymous()

익명 사용자인지.

is_authenticated()

사용자가 인증을 통과하고 로그인했는지 여부입니다.

get_full_name()

first_name과 last_name 사이에 공백을 포함하여 반환합니다.

get_short_name()

first_name을 반환합니다.

set_password(raw_password)

비밀번호를 설정하세요.

check_password(raw_password)

비밀번호를 확인하세요.

get_group_permissions(obj=None)

사용자 그룹 권한 모음을 반환합니다.

get_all_permissions(obj=None)

사용자의 모든 권한 집합을 반환합니다.

has_perm(perm, obj=None)

사용자에게 특정 권한이 있는지 여부입니다. perm의 형식은 "."입니다.

has_perms(perm_list, obj=None)

사용자가 권한 목록에 있는 각 권한을 가지고 있는지 여부입니다.

사용자 생성


User 객체의 비밀번호는 일반 텍스트로 저장되지 않으므로 User 객체 생성은 일반적인 Model create와 다르며 내장된 create_user() 메소드가 필요합니다. .

>>> from django.contrib.auth.models import User
>>> user = User.objects.create_user('john', 'lennon@thebeatles.com', 'johnpassword ')

# 이 시점에서 user는 이미 데이터베이스에 저장된
# User 개체입니다. 다른 필드를 변경하려면 해당 속성을 계속 변경할 수 있습니다
#.
>>> user.last_name = 'Lennon'
>>> user.save()

물론 관리자에서도 사용자를 추가할 수 있습니다. 인터페이스.

수퍼유저 생성

$ python Manage.py createsuperuser --username=joe --email=joe@example.com

비밀번호 변경

내장된 set_password() 메소드를 사용하세요.

>>> from django.contrib.auth.models import User
>>> u = User.objects.get(username='john')
> >> u.set_password('새 비밀번호')
>>> u.save()

사용자 인증

authenticate()

주어진 사용자 이름과 비밀번호가 유효한 사용자인지 확인하세요. 유효하면 User 객체가 반환되고, 유효하지 않으면 None이 반환됩니다.

from django.contrib.auth import authenticate
user = authenticate(username='john',password='secret')
if user is not None:
# 확인된 비밀번호 the user
if user.is_active:
print("사용자가 유효하고 활성 상태이며 인증되었습니다.")
else:
print("비밀번호는 유효하지만 계정이 비활성화되었습니다!")
else:
# 인증 시스템에서 사용자 이름과 비밀번호를 확인할 수 없습니다
print("사용자 이름과 비밀번호가 올바르지 않습니다.")

위는 Django 사용자입니다. 인증 시스템 (1) User 객체의 내용에 대한 자세한 내용은 PHP 중국어 웹사이트(www.php.cn)를 참고하세요!


성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.