Django的Auth模块提供了用户认证系统,它处理用户账号、组、权限以及基于cookie的用户会话。以下是使用Django Auth模块的一些基本方法:
- 用户模型:
 
Django自带一个用户模型,你可以直接使用它。在你的项目中,你可以通过以下方式导入和使用它:
from django.contrib.auth.models import User
 
# 创建一个新用户
new_user = User.objects.create_user('username', 'email@example.com', 'password')
 
# 更改密码
new_user.set_password('new password')
new_user.save()
- 用户认证:
 
Django的Auth模块提供了一个方法来验证用户名及密码:
from django.contrib.auth import authenticate
 
user = authenticate(username='username', password='password')
 
if user is not None:
    # A backend authenticated the credentials
    print('认证成功')
else:
    # No backend authenticated the credentials
    print('认证失败')
- 登录用户:
 
Django提供了一个login方法,可以用来登录用户:
from django.contrib.auth import login
 
def my_view(request):
    username = request.POST['username']
    password = request.POST['password']
    user = authenticate(username=username, password=password)
    if user is not None:
        login(request, user)
        # Redirect to a success page.
        ...
    else:
        # Return an 'invalid login' error message.
        ...
- 登出用户:
 
Django提供了一个logout方法,可以用来登出用户:
from django.contrib.auth import logout
 
def logout_view(request):
    logout(request)
    # Redirect to a success page.
- 检查用户权限:
 
Django的Auth模块可以用来检查用户是否有权限执行某个操作:
from django.contrib.auth.decorators import login_required
 
@login_required
def my_view(request):
    ...
- 装饰器:
 
Django的Auth模块提供了几个用于限制视图访问的装饰器。@login\_required装饰器会要求用户必须登录才能访问视图:
from django.contrib.auth.decorators import login_required
 
@login_required
def my_view(request):
    ...
user\_passes\_test和user\_passes\_test装饰器可以用来检查用户是否满足某个条件:
from django.contrib.auth.decorators import user_passes_test
 
def is_21(user):
    return user.age >= 21
 
@user_passes_test(is_21)
def my_view(request):
    ...
- 创建和管理组:
 
Django的Auth模块也提供了组的支持。你可以创建组并将用户添加到组中,然后对组应用权限:
from django.contrib.auth.models import Group
 
# 创建一个新组
group = Group.objects.create(name='group name