Django 之 auth 模块

Django 内置一个 auth 模块,帮助用户实现注册、登录、注销以及修改密码等功能,帮助开发者省去了很多功夫。

auth 模块

在创建模型时,Django内部会生成一个名为 auth_user 的数据表,用于存储认证的用户信息。

auth 模块提供了一系列的方法,使用之前需要导入:

from django.contrib import auth

authenticate() 方法

提供用户认证功能,验证用户名和密码是否正确等。如验证成功,则返回一个 User 对象。

from django.contrib import auth

def login(request):
    if request.method == 'POST':
        username = request.POST.get('username')
        password = request.POST.get('password')

         # 用户认证,验证用户名、密码是否正确,并返回一个 user 对象
         # username、password 字段对应 auth_user 表中相应字段
        user_obj = auth.authenticate(username=username, password=password)

login() 方法

实现用户登录功能,会在后台为登录用户生成 session 数据。

from django.contrib import auth
auth.login(request, user_obj)

from django.contrib.auth import login
login(request, user_obj)

接收两个参数,第一个为 HTTPRequest 对象,以及一个认证过的用户对象(即 authenticate() 认证过的用户对象)。

from django.contrib import auth

def login(request):
    """登录"""
    if request.method == 'POST':
        username = request.POST.get('username')
        password = request.POST.get('password')

        # 用户认证,验证用户名、密码是否正确,并返回一个 user 对象
        user_obj = auth.authenticate(username=username, password=password)
        if user_obj:
            # 将验证成功的用户封装到 request.user 对象中
            auth.login(request, user_obj)
            return redirect('home')
        else:
            return '错误信息'
    return render(request, 'login.html')

认证成功的用户对象,执行 login() 方法,实现登录功能,否则返回错误信息。

Tips

执行过 login() 方法的用户对象,就能通过request.user 拿到当前登录的用户对象,从而取出用户的相关信息,否则取得的将是一个匿名用户对象 AnonymounsUser Object

login(request, user_obj)
# 获得当前登录用户对象
user = request.user
# 获得当前登录用户对象的用户名
username = request.user.username

logout() 方法

该方法实现注销功能,清除当前登录用户数据库中的 session 数据,接收一个 HttpRequest 对象,无返回值。

from django.contrib import auth

def logout(request):
    """注销"""
    auth.logout(request)
    # 注销后重定向到登录页面
    return redirect('login')

is_authenticated 属性

判断当前用户是否通过认证,为布尔值。

def home(request):
    """首页"""
    ret = request.user.is_authenticated
    print(ret)      # True

login_required() 方法

auth 模板提供的一个装饰器工具,能够便捷地为某个视图添加登录校验。

  • 若用户没有登录,则默认会跳转到 accounts/login/,并传递当前访问 url 绝对路径。
  • 自定义跳转路径,只需在 settings.py 中添加:
# 当用户没有登录,访问某个视图时将会跳转到登录页面
LOGIN_URL = '/login/'
from django.contrib.auth.decorators import login_required

# 添加装饰器
@login_required
def home(request):
    """首页"""

    return render(request, 'home.html')

当用户访问 home 页面时,若没有登录则会跳转到登录页面,否则返回 home 页面。

用户相关

上面介绍的都是关于登录相关的,下面将介绍如何创建在 auth_user 中创建用户,修改密码,验证密码等。

create_superuser() 方法

该方法用于创建一个超级用户,接收 username、password 两个必要参数。效果与执行 python manage.py createsuperuser 等同。

from django.contrib.auth.models import User

user_obj = User.objects.create_superuser(username='用户名',password='密码',email='邮箱',...)

create_user() 方法

一般情况 create_superuser() 方法很少使用,最常使用的是create_user() 方法,它将会创建一个普通用户,常应用于注册视图中。

创建用户所需字段,应与 auth_user 数据表中字段对应。

from django.contrib.auth.models import User

def signup(request):
    # 创建新用户
    user_obj = User.objects.create_user(username='lila', password='1234')

    return HttpResponse('创建成功')

Tips

新创建的用户,保存在 auth_user数据表中的密码是经过加密的。

check_password() 方法

检查登录用户密码是否正确,需要当前请求用户的密码。

from django.contrib.auth.models import User

def signup(request):
    # 创建新用户
    user_obj = User.objects.create_user(username='lila', password='1234')

    ret = user_obj.check_password('123456')
    print(ret)      # False
    return HttpResponse('创建成功')

密码正确返回 True,否则返回 False。

或者对当前请求的 user 对象校验原密码是否正确:

obj = request.user.check_password(raw_password='原始密码')

set_password() 方法

该方法用于修改密码,接收要新密码作为参数,最后一定要执行 save() 方法保存,否则无效。

def set_password(request):
    """
    修改密码,request.user 中封装了已认证且执行了登录功能的用户对象
    :param request:
    :return:
    """
    request.user.set_password('12')
    password = request.user.password
    request.user.save()
    print(password)

    return HttpResponse('修改成功')

修改密码示例

该示例仅适用于已登录的用户,在内部修改密码,未登录的用户将跳转到登录页面。

from django.shortcuts import render, redirect, HttpResponse
from django.contrib.auth.decorators import login_required

@login_required
def set_password(request):
    """
    修改密码,request.user 中封装了已认证且执行了登录功能的用户对象
    :param request:
    :return:
    """
    user = request.user
    ret = {'message': None}
    if request.method == 'POST':
        old_password = request.POST.get('old_password')
        new_password = request.POST.get('new_password')
        # 重复新密码
        repeat_password = request.POST.get('repeat_password')
        # 检查旧密码是否正确
        if user.check_password(old_password):
            if not new_password:
                ret['message'] = '新密码不能为空'

            elif new_password != repeat_password:
                ret['message'] = '两次密码输入不一致'
            else:
                user.set_password(new_password)
                user.save()
                return redirect('login')
        else:
            ret['message'] = '原密码不正确'
    return render(request, 'set_password.html', ret)

auth 模块拓展

由于 auth 模板中 auth_user 数据表字段是固定的,因此当我们使用 auth 模块,想要添加额外的字段时,就需要对其进行拓展。

拓展方法有两种:

  • 模型中新增一个表,与 auth_user 表一对一关联
  • 继承内置的 AbstractUser 类:常用
  1. 模型 models.py 中新建一个类,继承自 AbstractUser
from django.contrib.auth.models import User, AbstractUser   # 导入 AbstractUser 类

class UserInfo(AbstractUser):
    """
    继承 AbstractUser
    新增字段:phone、addr
    """
    phone = models.CharField(max_length=11, verbose_name='手机号码')
    addr = models.CharField(max_length=128, verbose_name='家庭地址')
  1. 配置 settings.py

新增的类继承 AbstractUser ,拓展后将会覆盖 auth_user 表,因此需要配置 settings,使默认认证知道要使用哪种表认证。

# settings.py
# 在最后添加如下代码
AUTH_USER_MODEL = 'app名.新增的类名'

AUTH_USER_MODEL = 'app.UserInfo'    # 示例
  1. 迁徙数据表
python manage.py makemigrations
python manage.py migrate
  1. 创建用户

拓展 auth 模块后,使用的不再是原来 auth_user 表,而是新表 app.UserInfo 表,因此在创建用户时应该注意。

# 拓展之前
from django.contrib.auth.models import User
user_obj = User.objects.create_user(username='lila', password='1234')

# 拓展之后
from app.models import UserInfo
user_obj = UserInfo.objects.create_user(username='lila', password='1234')

Tips

  • 若已经迁徙了模型,拓展 auth 模块时,需要将 migrations 文件夹下文件(如:0001_initial.py文件删除),否则会报 ValueError: Related model u‘app.model‘ cannot be resolved
  • 若还没有迁徙模型,那么正常执行即可。

原文地址:https://www.cnblogs.com/midworld/p/10992027.html

时间: 2024-08-30 14:42:44

Django 之 auth 模块的相关文章

Django之auth模块(用户认证)

auth模块简介 auth模块是对登录认证方法的一种封装,之前我们获取用户输入的用户名及密码后需要自己从user表里查询有没有用户名和密码符合的对象, 而有了auth模块之后就可以很轻松的去验证用户的登录信息是否存在于数据库中. 除此之外,auth还对session做了一些封装,方便我们校验用户是否已登录 auth里的方法 首先导入模块 from django.contrib import auth 1 .authenticate()   提供了用户认证,即验证用户名以及密码是否正确,一般需要u

Django之auth模块(用户认证)登陆组件

auth模块简介 auth模块是对登录认证方法的一种封装,之前我们获取用户输入的用户名及密码后需要自己从user表里查询有没有用户名和密码符合的对象, 而有了auth模块之后就可以很轻松的去验证用户的登录信息是否存在于数据库中. 除此之外,auth还对session做了一些封装,方便我们校验用户是否已登录 auth里的方法 如果想使用auth模块的方法,必须要先导入auth模块 from django.contrib import auth django.contrib.auth中提供了许多方法

Django之Auth模块

1 Auth模块是什么 Auth模块是Django自带的用户认证模块: 我们在开发一个网站的时候,无可避免的需要设计实现网站的用户系统.此时我们需要实现包括用户注册.用户登录.用户认证.注销.修改密码等功能,这还真是个麻烦的事情呢. Django作为一个完美主义者的终极框架,当然也会想到用户的这些痛点.它内置了强大的用户认证系统--auth,它默认使用 auth_user 表来存储用户数据. 2 auth模块常用方法 from django.contrib import auth authent

Django之auth模块用户认证模块

一.Auth模块 1)auth模块是什么.登录后台使用的账号密码,则就是使用的auth模块创建的表 Auth模块是Django自带的用户认证模块: 我们在开发一个网站的时候,无可避免的需要设计实现网站的用户系统. 此时我们需要实现包括用户注册.用户登录.用户认证.注销.修改密码等功能,这还真是个麻烦的事情呢. Django作为一个完美主义者的终极框架,当然也会想到用户的这些痛点.它内置了强大的用户认证系统--auth, 它默认使用 auth_user 表来存储用户数据. 2)auth模块的功能

Django的auth模块

首先我们先来复习一下路由别名如何使用,这里仅仅复习一下二级路由的路由别名该如何使用 ·1.在视图函数中使用二级路由别名,需要加上app的名称+":"+ "路由别名" from django.urls import reverse return redirect(reverse("app1:auth_index_view")) 2.在html文件中使用二级路由的别名 <form action="{% url 'app1:auth_l

Django对中间件的调用思想、csrf中间件详细介绍、Django settings源码剖析、Django的Auth模块

目录 使用Django对中间件的调用思想完成自己的功能 功能要求 importlib模块介绍 功能的实现 csrf中间件详细介绍 跨站请求伪造 Django csrf中间件 form表单 ajax csrf相关装饰器 在CBV上加csrf装饰器 Django settings源码剖析及模仿使用 Django settings源码剖析 查看内部配置文件 模仿使用 Auth模块 auth简介 auth模块常用方法 创建用户 校验用户名和密码 保存用户登录状态 判断当前用户是否登录 校验原密码 修改密

python之auth模块

django之auth模块 ''' 今天傻逼了,整理了很久的笔记,结果因为更新了navigate,忘记保存重启,内存清空,数据都丢了,所以我先把今天所学的知识,大体讲一下,周末再具体进行补充. ''' #auth模块主要就是围绕用户表,完成用户登录注册,修改密码,添加字段等作用的,可以加语法糖,全局,局部配置, #然后可以用auth模块可以对字段进行扩充,就是继承,再加个配置 ##下面是粗略的笔记,周六上午重新整理完 1.auth模块 用auth模块 你就用全套 不是自己写一部分 用别人一部分

CSRF与auth模块

目录 一.模拟实现中间件的编程思想 (一)impotlib模块 (二)实现功能的配置使用 二.跨站请求伪造CSRF (一)由来 (二)form表单的CSRF (三)ajax中的CSRF (1)通过data携带 (2)通过headers携带 (3)官网提供的文件(推荐用法) (四)CSRF相关的装饰器 (1)MTV模型中使用 (2)CBV模型中使用 三.Django中auth模块 (一)什么是auth模块 (二)常用方法 (1)创建用户 (2)校验用户 (3)登录保存 (4)是否登录 (5)检验密

扩展Django内置的auth模块代码示例

一,创建自定义User模型类.继承AbstractUser 方法1 新建一个表,表里面有手机号,邮箱,地址,一对一与User表进行关联 方法2 新定义一个类,继承类AbstractUser ( auth模块的User类也是继承此AbstractUser 类的) 说明:python 语法上,也是可以直接继承User类的 以下代码,我们扩展了两个字段,phone和addr 注意:settings.py中一定要指不使用内置的User表,而是使用新的UserInfo表 AUTH_USER_MODEL='