【Django】Django用户认证: 利用Django Auth模块实现用户注册、登录与登出

Django用户认证: 利用Django Auth模块实现用户注册、登录与登出

用户登录注册属于用户认证的一部分,Django内置了一套用户认证体系,使用起来比较方便,而且支持用户定制和拓展,足以满足任何复杂的业务需求。


在这里插入图片描述



1 Django 用户管理机制

Django框架中,用户权限管理被划分为三个层次:

  • 用户:系统使用者,拥有自己的权限。可被一个或多个用户组包含。
  • 用户组:对用户进行分类。同一用户组拥有相同的权限。
  • 权限:用于约束用户行为。Django中一个完整的权限除权限本身外,还包括用户和对象,即什么用户对什么对象具有什么样的权限。

2 Auth模块

Auth模块是Django框架内置的权限管理模块。利用Auth模块可以实现用户身份认证、用户组和权限管理。

2.1 配置权限管理模块

在项目配置文件settings.py中加入以下代码:

INSTALLED_APPS = [
	'django.contrib.admin',
	'django.contrib.auth', # 权限管理模块
	'django.contrib.contenttypes', # 内容管理模块
]

2.2 Auth模块中的用户模型 用户组模型 用户权限模型

模块名称说明
Django.contrib.auth.models.UserAuth模块中的用户模型
Django.contrib.auth.models.GroupAuth模块中的组模型
Django.contrib.auth.models.PermissionAuth模块中的权限模型

3 Django自带的用户模型(User)介绍

3.1 User模型内置字段介绍

用户模型是Django用户认证的核心,用户模型内置了多个字段可直接使用。

内置字段名称说明字段类型
id数据库主键int
password密码varchar
last_login最近登录时间datetime
is_superuser是否超级管理员tinyint
user_name用户账号varchar
email邮箱varchar
is_staff是否登录admin后台tinyint
is_active是否激活tinyint
date_joined账号创建时间datetime

3.2 User模型内置方法

内置方法名称说明
authenticate(username, password)用于用户认证。认证成功,则返回一个User对象
login(HttpRequest, user)用于用户登录。user参数是经过认证的User对象。登录成功后将用户身份信息记录到请求的会话对象中存储。后台使用request.user可获取当前登录的用户对象。如果未登录成功,则request.user得到的是一个匿名用户对象。
is_authenticated()判断当前用户是否经过认证
logout(request)清除当前请求,注销会话
create_user()创建新用户,至少提供用户名和密码
set_password(password)修改密码
check_password(password)检查密码是否正确

上述内置方法,可以在用户校验时为我们提供巨大的方便。
用户创建项目和应用后,执行完数据迁移,后台会生成一套auth开头的用户权限数据表。


4 基于User模型的功能开发

4.1 用户注册

在视图文件views.py中:

# # 导入模块
from django.shortcuts import render, redirect
from django.http import HttpResponse, JsonResponse
from django.contrib.auth.models import User
from django.contrib.auth import authenticate, logout

def register(request):
	if request.method == 'GET':
		return render(
			request,
			'basic/register.html'
		)
	
	elif request.method == 'POST':
		# 获取参数
		user_name = request.POST.get('username', '')
		pwd = request.POST.get('password', '')
		
		# 用户已存在
		if User.objects.filter(username=user_name):
			return JsonResponse({
				'code': 200,
				'msg': '用户已存在'
			})
		# 用户不存在
		else:
			# 使用User内置方法创建用户
			user = User.objects.create_user(
				username=user_name,
				password=pwd,
				email='123@qq.com',
				is_staff=1,
				is_active=1,
				is_superuser=0
			)
			
			return JsonResponse({
				'code': 200,
				'msg': '用户注册成功'
			})
	
	else:
		return JsonResponse({
			'code': 403,
			'msg': '被禁止的请求'
		})

4.2 用户登录

在视图文件views.py中:

"""此处导入的模块和注册是一样的"""

def login(request):
	if request.method == 'GET':
		return render(
			request,
			'basic/login.html',
		)
	
	elif request.method == 'POST':
		# 获取参数
		user_name = request.POST.get('username', '')
		pwd = request.POST.get('password', '')
		
		# 用户已存在
		if User.objects.filter(username=user_name):
			# 使用内置方法验证
			user = authenticate(username=user_name, password=pwd)
			
			# 验证通过
			if user:
				# 用户已激活
				if user.is_active:
					return JsonResponse({
						'code': 200,
						'msg': '登录成功'
					})
				# 未激活
				else:
					return JsonResponse({
						'code': 200,
						'msg': '用户未激活'
					})
			
			# 验证失败
			else:
				return JsonResponse({
					'code': 403,
					'msg': '用户认证失败'
				})
		
		# 用户不存在
		else:
			return redirect('/basic/register')

4.3 用户登出

"""此处导入的模块和注册是一样的"""
def logout(request):
	logout(request)
	return redirect('/basuc/login')

  • 20
    点赞
  • 82
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
好的,下面是基于 Django auth 模块登录和注册模块的示例代码: ## 注册模块 ### 1. 创建注册页面 在 templates 目录下创建一个 register.html 文件,该文件包含一个表单,用户可以输入用户名和密码: ```html <!DOCTYPE html> <html> <head> <title>注册</title> </head> <body> <h2>注册</h2> <form method="post"> {% csrf_token %} {{ form.as_p }} <button type="submit">注册</button> </form> </body> </html> ``` ### 2. 创建注册视图 在 views.py 文件中创建一个 register 视图,该视图处理用户提交的注册表单,并将新用户保存到数据库中: ```python from django.shortcuts import render, redirect from django.contrib.auth.forms import UserCreationForm def register(request): if request.method == 'POST': form = UserCreationForm(request.POST) if form.is_valid(): form.save() return redirect('login') else: form = UserCreationForm() return render(request, 'register.html', {'form': form}) ``` 在上面的代码中,我们使用 Django 自带的 UserCreationForm 表单处理用户提交的注册表单。如果表单数据有效,我们将表单数据保存到数据库中,并将用户重定向到登录页面。 ## 登录模块 ### 1. 创建登录页面 在 templates 目录下创建一个 login.html 文件,该文件包含一个表单,用户可以输入用户名和密码: ```html <!DOCTYPE html> <html> <head> <title>登录</title> </head> <body> <h2>登录</h2> <form method="post"> {% csrf_token %} {{ form.as_p }} <button type="submit">登录</button> </form> </body> </html> ``` ### 2. 创建登录视图 在 views.py 文件中创建一个 login 视图,该视图处理用户提交的登录表单,并验证用户名和密码是否匹配: ```python from django.shortcuts import render, redirect from django.contrib.auth.forms import AuthenticationForm from django.contrib.auth import authenticate, login def login_view(request): if request.method == 'POST': form = AuthenticationForm(data=request.POST) if form.is_valid(): username = form.cleaned_data.get('username') password = form.cleaned_data.get('password') user = authenticate(username=username, password=password) if user is not None: login(request, user) return redirect('home') else: form = AuthenticationForm() return render(request, 'login.html', {'form': form}) ``` 在上面的代码中,我们使用 Django 自带的 AuthenticationForm 表单处理用户提交的登录表单。如果表单数据有效,我们使用 authenticate 函数验证用户名和密码是否匹配。如果匹配成功,我们使用 login 函数将用户登录到系统中,并将用户重定向到网站首页。 ### 3. 创建网站首页 在 urls.py 文件中创建一个网站首页的路由: ```python from django.urls import path from .views import register, login_view, home urlpatterns = [ path('register/', register, name='register'), path('login/', login_view, name='login'), path('', home, name='home'), ] ``` 在 views.py 文件中创建一个 home 视图,该视图返回网站首页的 HTML 页面: ```python from django.shortcuts import render def home(request): return render(request, 'home.html') ``` 在 templates 目录下创建一个 home.html 文件,该文件包含网站首页的 HTML 代码。 这就是基于 Django auth 模块登录和注册模块的示例代码。希望对你有所帮助。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

勇敢牛马 不怕困难

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值