【Django】Django内建用户系统

2024-02-11 04:20
文章标签 系统 django 用户 内建

本文主要是介绍【Django】Django内建用户系统,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Django内建用户系统

14.1 Django中的用户认证

  • Django带有一个用户认证系统系统,它处理用户用户账号、组、权限以及基于cookie的用户会话。

  • 用户可以直接使用Django自带的用户表。

  • 官方文档:https://docs.djangoproject.com/zh-hans/2.2/topics/auth/

14.2 用户系统表的基本字段

模型类位置 from django.contrib.auth.models import User

字段名含义
username用户名
password密码
email邮箱
first_name
last_name
is_superuser是否管理员账号
is_staff是否可以访问admin管理界面
is_active是否是活跃用户,默认为True,一般不删除用户,而是将用户的is_active设为False
last_login上一次登录时间
date_joined用户创建的时间

14.3 用户系统的基本模型操作

  1. 创建普通用户 create_user:

    from django.contrib.auth.models import User
    user = User.objects.create_user(username='用户名', password='密码', email='邮箱', ...)

  2. 创建超级用户 create_superuser:

    from django.contrib.auth.models import User
    user = User.objects.create_superuser(username='用户名', password='密码', email='邮箱', ...)

  3. 删除用户:

    from django.contrib.auth.models import User
    try:user = User.objects.get(username='用户名')user.is_active = Falseuser.save()print("删除普通用户成功")
    except:print("删除普通用户失败")

  4. 校验密码:

    # 说明:如果用户名密码校验成功则返回对应的User对象,否则返回None
    from django.contrib.auth import authenticate
    user = authenticate(username=username, password=password)

  5. 修改密码:

    from django.contrib.auth.models import User
    try:user = User.objects.get(username='用户名')user.set_password('123456')user.save()print("修改密码成功")
    except:print("修改密码失败")

  6. 登录状态保持:

    from django.contrib.auth import login,authenticate
    def login_view(request):user = authenticate(username='用户名', password='密码')login(request, user)

  7. 登录状态校验:

    from django.contrib.auth.decorators import login_required
    @login_required
    def index_view(request):# 该视图必须为用户登录状态下才可以访问# 当前登录用户可以通过request.user获取login_user = request.user...

  8. 用户注销登录:

    from django.contrib.auth import logout
    def logout_view(request):logout(request)

代码示例:

  1. 创建 templates 目录,放置 html 页面。

  2. 编写对应的template页面。

    register.html,用户注册页。

    <!DOCTYPE html>
    <html lang="en">
    <head><meta charset="UTF-8"><title>Register</title>
    </head>
    <body><form method="post" action="{% url 'register_page' %}">{% csrf_token %}{{ form }}<input type="submit" value="Submit"></form>
    </body>
    </html>

    login.html,用户登录页。

    <!DOCTYPE html>
    <html lang="en">
    <head><meta charset="UTF-8"><title>Login</title>
    </head>
    <body><form method="post" action="{% url 'login' %}">{% csrf_token %}{{ form }}<input type="submit" value="Submit"></form>
    </body>
    </html>

    homepage.html,首页。

    <!DOCTYPE html>
    <html lang="en">
    <head><meta charset="UTF-8"><title>homepage</title>
    </head>
    <body><form method="post" action="{% url 'logout' %}">{% csrf_token %}欢迎访问项目<input type="submit" value="注销用户"></form>
    </body>
    </html>

  3. 编写对应的视图函数。

    from django.shortcuts import render
    from django.contrib.auth.models import User
    from django.http import HttpResponseRedirect, HttpResponse
    from django.contrib.auth import authenticate, login, logout
    from .forms import loginForm, registerForm
    from django.contrib.auth.decorators import login_required
    ​
    # Create your views here.
    def login_page(request):"""项目登录面:param request::return:"""# return render(request, 'hello.html')if request.method == 'POST':form = loginForm(request.POST)if form.is_valid():# 处理表单提交逻辑,可以访问 form.cleaned_data 获取表单字段的值username = form.cleaned_data['username']password = form.cleaned_data['password']if not username or not password:return HttpResponse("请输入正确的参数")# 校验密码user = authenticate(username=username, password=password)print('校验用户')print(user)if not user:return HttpResponse("用户名或密码错误")else:# 记录会话状态login(request, user)return HttpResponseRedirect('/homepage')else:form = loginForm()
    ​return render(request, 'login.html', {'form': form})
    ​
    ​
    def register_page(request):"""项目注册页面:param request::return:"""# return render(request, 'hello.html')if request.method == 'POST':form = registerForm(request.POST)if form.is_valid():# 处理表单提交逻辑,可以访问 form.cleaned_data 获取表单字段的值username = form.cleaned_data['username']password1 = form.cleaned_data['password1']password2 = form.cleaned_data['password2']if not username or not password1 or not password2:return HttpResponse("请传入正确的参数")# 进行注册操作try:if password1 != password2:return HttpResponse("两次输入的密码不一致")# 创建用户user = User.objects.create_user(username=username, password=password1)# 注册成功return HttpResponseRedirect('/login')except Exception as e:# 注册失败print(e)return HttpResponse("注册用户失败,请联系管理员进行处理")else:form = registerForm()
    ​return render(request, 'register.html', {'form': form})
    ​
    def logout_func(request):"""注销登录:param request::return:"""logout(request)return HttpResponseRedirect('/login')

  4. 编写对应的路由函数。

    from django.urls import path, re_path
    from . import views
    urlpatterns = [path("", views.login_page, name='login'),path("register/", views.register_page, name='register_page'),path("logout/", views.logout_func, name='logout')
    ]

  5. 配置项目默认的登录页面。

    # settings.py
    # 配置了登录地址,当访问到需要登录的页面时,如果此时用户未登录,则跳转至登录页面
    LOGIN_URL = '/login'

  6. 页面调用测试。

    注册页面输入用户名,密码,确认密码后点击submit进行登录。

    成功注册后,跳转至login页面,输入刚才注册的用户名和密码,点击submit进行登录。

    登录成功,跳转至项目首页。

    再打开一个标签页,注销登录后,项目首页无法访问。

14.4 用户系统的扩展字段

  • 通过建立新表,跟内建表做一对一映射。

  • 继承内建的抽象User模型类。

14.4.1 继承内部抽象类

步骤:

  1. 添加新的应用。

  2. 定义模型类,集成AbstractUser。

  3. settings.py中指明AUTH_USER_MODEL='应用名.类名'。

注:该操作需要在第一次migrate之前进行,否则会报如下的错误。

代码测试:

  1. 添加新的应用。

    python3 manage.py startapp useradmin

  2. 定义模型类,集成AbstractUser。

    from django.db import models
    from django.contrib.auth.models import AbstractUser
    # Create your models here.
    ​
    class UserInfo(AbstractUser):
    ​phone = models.CharField(max_length=11, default='')

  3. settings.py中指明AUTH_USER_MODEL='应用名.类名'。

    AUTH_USER_MODEL = 'useradmin.UserInfo'

  4. 执行代码迁移。

    python3 manage.py makemigrations
    python3 manage.py migrate
  5. 迁移成功后,查看数据库,auth_user表消失,出现了一个useradmin_userinfo的表。

  6. 创建新用户测试。

    from django.contrib.auth.models import User
    user = User.objects.create_user(username='euansu', password='euansu', email='euansu@euansu.cn', phone=13000000000)

    查看数据库

    使用新创建的用户登录刚才的项目,可以正常登录。

这篇关于【Django】Django内建用户系统的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/698814

相关文章

JWT + 拦截器实现无状态登录系统

《JWT+拦截器实现无状态登录系统》JWT(JSONWebToken)提供了一种无状态的解决方案:用户登录后,服务器返回一个Token,后续请求携带该Token即可完成身份验证,无需服务器存储会话... 目录✅ 引言 一、JWT 是什么? 二、技术选型 三、项目结构 四、核心代码实现4.1 添加依赖(pom

基于Python实现自动化邮件发送系统的完整指南

《基于Python实现自动化邮件发送系统的完整指南》在现代软件开发和自动化流程中,邮件通知是一个常见且实用的功能,无论是用于发送报告、告警信息还是用户提醒,通过Python实现自动化的邮件发送功能都能... 目录一、前言:二、项目概述三、配置文件 `.env` 解析四、代码结构解析1. 导入模块2. 加载环

linux系统上安装JDK8全过程

《linux系统上安装JDK8全过程》文章介绍安装JDK的必要性及Linux下JDK8的安装步骤,包括卸载旧版本、下载解压、配置环境变量等,强调开发需JDK,运行可选JRE,现JDK已集成JRE... 目录为什么要安装jdk?1.查看linux系统是否有自带的jdk:2.下载jdk压缩包2.解压3.配置环境

Python库 Django 的简介、安装、用法入门教程

《Python库Django的简介、安装、用法入门教程》Django是Python最流行的Web框架之一,它帮助开发者快速、高效地构建功能强大的Web应用程序,接下来我们将从简介、安装到用法详解,... 目录一、Django 简介 二、Django 的安装教程 1. 创建虚拟环境2. 安装Django三、创

Linux查询服务器系统版本号的多种方法

《Linux查询服务器系统版本号的多种方法》在Linux系统管理和维护工作中,了解当前操作系统的版本信息是最基础也是最重要的操作之一,系统版本不仅关系到软件兼容性、安全更新策略,还直接影响到故障排查和... 目录一、引言:系统版本查询的重要性二、基础命令解析:cat /etc/Centos-release详

更改linux系统的默认Python版本方式

《更改linux系统的默认Python版本方式》通过删除原Python软链接并创建指向python3.6的新链接,可切换系统默认Python版本,需注意版本冲突、环境混乱及维护问题,建议使用pyenv... 目录更改系统的默认python版本软链接软链接的特点创建软链接的命令使用场景注意事项总结更改系统的默

在Linux系统上连接GitHub的方法步骤(适用2025年)

《在Linux系统上连接GitHub的方法步骤(适用2025年)》在2025年,使用Linux系统连接GitHub的推荐方式是通过SSH(SecureShell)协议进行身份验证,这种方式不仅安全,还... 目录步骤一:检查并安装 Git步骤二:生成 SSH 密钥步骤三:将 SSH 公钥添加到 github

Django中的函数视图和类视图以及路由的定义方式

《Django中的函数视图和类视图以及路由的定义方式》Django视图分函数视图和类视图,前者用函数处理请求,后者继承View类定义方法,路由使用path()、re_path()或url(),通过in... 目录函数视图类视图路由总路由函数视图的路由类视图定义路由总结Django允许接收的请求方法http

Django HTTPResponse响应体中返回openpyxl生成的文件过程

《DjangoHTTPResponse响应体中返回openpyxl生成的文件过程》Django返回文件流时需通过Content-Disposition头指定编码后的文件名,使用openpyxl的sa... 目录Django返回文件流时使用指定文件名Django HTTPResponse响应体中返回openp

Django开发时如何避免频繁发送短信验证码(python图文代码)

《Django开发时如何避免频繁发送短信验证码(python图文代码)》Django开发时,为防止频繁发送验证码,后端需用Redis限制请求频率,结合管道技术提升效率,通过生产者消费者模式解耦业务逻辑... 目录避免频繁发送 验证码1. www.chinasem.cn避免频繁发送 验证码逻辑分析2. 避免频繁