百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 编程字典 > 正文

Django4.1学习笔记2023-9-1使用 Django 的验证系统

toyiye 2024-09-19 04:52 3 浏览 0 评论

官方地址:https://docs.djangoproject.com/zh-hans/4.1/topics/auth/default/

---------------有些内容之前已经介绍过,此页内容有部分需要结合之前所学内容------

在Django中,认证和授权是通过内置的认证系统来实现的。这个系统包括了用户管理、身份验证、会话管理等功能。开发者可以通过使用Django提供的视图和模板来处理用户的登录、注册、注销等操作。

下面是一些我在学习Django框架时学到的知识:

  1. Django内置了认证系统,包括了用户管理、身份验证、会话管理等功能。开发者可以通过使用Django提供的视图和模板来处理用户的登录、注册、注销等操作。
  2. Django提供了多种认证方式,包括了用户名/密码认证、电子邮件认证、手机号码认证等。开发者可以根据实际需求选择合适的认证方式。
  3. Django内置了会话管理功能,可以帮助开发者管理用户会话。开发者可以使用Django提供的会话管理工具来存储和管理用户会话信息。
  4. Django提供了多种权限控制机制,包括了基于角色的访问控制、基于属性的访问控制等。开发者可以根据实际需求选择合适的权限控制机制。
  5. Django提供了多种视图和模板,可以帮助开发者处理用户的请求和响应。开发者可以使用Django提供的视图和模板来构建Web应用程序。

下面是一个简单的示例代码,演示了如何使用Django内置的认证系统进行用户登录:

from django.contrib.auth import authenticate, login

# 定义一个视图函数,用于处理用户登录请求
def user_login(request):
    if request.method == 'POST':
        # 获取用户提交的用户名和密码
        username = request.POST['username']
        password = request.POST['password']
        
        # 使用Django内置的认证系统进行用户认证
        user = authenticate(request, username=username, password=password)
        
        # 如果用户认证成功,则登录用户并返回响应
        if user is not None:
            login(request, user)
            return HttpResponse('登录成功!')
        else:
            return HttpResponse('用户名或密码错误!')
    else:
        # 如果请求方法不是POST,则返回一个空的表单页面
        return render(request, 'login.html')

在上面的代码中,我们首先导入了Django内置的authenticate和login函数。然后定义了一个名为user_login的视图函数,用于处理用户登录请求。在这个函数中,我们首先获取了用户提交的用户名和密码,然后使用authenticate函数进行用户认证。如果用户认证成功,则使用login函数登录用户并返回响应;否则返回一个错误提示页面。最后,我们使用render函数渲染了一个名为login.html的模板页面,用于显示登录表单。

下面是我学习Django框架时了解到的一些知识,以及一些样例代码和说明:

  1. Django中的认证系统

Django内置了一个认证系统,可以用于处理用户的登录、注销、权限验证等功能。在Django中,认证是通过视图函数和模板来实现的。开发者需要定义一些视图函数,来处理用户的登录、注销、密码重置等操作,并使用模板来渲染登录表单、注销提示信息等页面。

  1. Django中的用户模型

Django内置了一个用户模型(User Model),用于存储和管理用户的信息。这个模型包含了用户名、密码、电子邮件地址等字段,并且提供了一些方法,如is_authenticated、get_full_name、set_password等,可以帮助开发者进行用户验证和授权。

  1. Django中的认证视图函数

Django内置了一些认证视图函数,可以用于处理用户的登录、注销、权限验证等操作。开发者只需要继承这些视图函数,并实现自己的逻辑即可。下面是一些常用的认证视图函数:

  • login:用于处理用户登录请求,返回一个HttpResponse对象或重定向到指定的URL。
  • logout:用于处理用户注销请求,清除用户的会话信息。
  • password_change/password_change_done/password_reset/password_reset_done:用于处理用户密码修改请求,发送重置密码链接到用户的邮箱或者执行其他的密码重置操作。
  • reset_password/password_reset_confirmation/password_reset_completed:用于处理用户密码重置确认请求,检查用户输入的旧密码是否正确。
  1. Django中的模板标签

Django提供了一些模板标签,可以方便地在模板中使用Python代码。比如{% if %}标签可以用来判断一个条件是否成立,{% for %}标签可以用来遍历一个序列,{% url %}标签可以用来生成一个URL等等。下面是一个简单的示例代码,演示了如何在模板中使用{% if %}标签来判断用户是否已经登录:

{% if user.is_authenticated %}
    <p>欢迎回来,{{ user.username }}!</p>
{% else %}
    <p>请先登录!</p>
    <a href="{% url 'login' %}">登录</a>
{% endif %}

在上面的代码中,我们首先判断用户是否已经登录,如果已经登录则显示欢迎信息;否则显示登录链接。其中,user是一个表示当前用户的变量,可以通过request.user获取。

结合oschina开源的Django项目,编写的一个详细的登录、登出项目的代码:

  1. 首先,我们需要在settings.py文件中配置认证相关的设置。这里我们使用Django内置的用户模型(User Model),并启用了认证系统和密码哈希功能。
# settings.py

INSTALLED_APPS = [
    # ...
    'django.contrib.auth',
    'django.contrib.contenttypes',
    # ...
]

AUTHENTICATION_BACKENDS = [
    'django.contrib.auth.backends.ModelBackend',
]

AUTH_USER_MODEL = 'auth.User'

PASSWORD_HASHERS = [
    'django.contrib.auth.hashers.PBKDF2PasswordHasher',
    'django.contrib.auth.hashers.PBKDF2SHA1PasswordHasher',
    'django.contrib.auth.hashers.BCryptSHA256PasswordHasher',
    'django.contrib.auth.hashers.BCryptPasswordHasher',
]
  1. 然后,我们需要定义一个视图函数,用于处理用户的登录请求。在这个函数中,我们首先检查用户是否已经登录,如果已经登录则直接返回一个HttpResponse对象;否则,我们调用Django内置的认证视图函数来处理登录请求,并重定向到指定的URL。
# views.py

from django.contrib.auth import authenticate, login
from django.http import HttpResponseRedirect
from django.shortcuts import render, redirect

def login_view(request):
    if request.method == 'POST':
        username = request.POST['username']
        password = request.POST['password']
        user = authenticate(request, username=username, password=password)
        if user is not None:
            login(request, user)
            return HttpResponseRedirect('/')
        else:
            return render(request, 'login.html', {'error': '用户名或密码错误!'})
    else:
        return render(request, 'login.html')
  1. 接下来,我们需要定义一个视图函数,用于处理用户的登出请求。在这个函数中,我们调用Django内置的注销视图函数来清除用户的会话信息。
# views.py

from django.contrib.auth import logout
from django.http import HttpResponseRedirect
from django.shortcuts import render, redirect

def logout_view(request):
    logout(request)
    return HttpResponseRedirect('/')
  1. 最后,我们需要定义两个模板文件,分别用于显示登录表单和登出提示信息。下面是一个示例代码,演示了如何在模板中使用Django内置的模板标签来实现这些功能:
<!-- login.html -->

<!DOCTYPE html>
<html>
<head>
    <title>登录</title>
</head>
<body>
    <h1>登录</h1>
    {% if error %}
        <p>{{ error }}</p>
    {% else %}
        <form method="post" action="{% url 'login' %}">
            {% csrf_token %}
            <label for="username">用户名:</label>
            <input type="text" name="username" required><br>
            <label for="password">密码:</label>
            <input type="password" name="password" required><br>
            <button type="submit">登录</button>
        </form>
    {% endif %}
</body>
</html>
<!-- logout.html -->

<!DOCTYPE html>
<html>
<head>
    <title>登出</title>
</head>
<body>
    <h1>登出</h1>
    <a href="{% url 'logout' %}">登出</a>
</body>
</html>

以上就是一个简单的登录、登出项目的代码。当然,在实际开发中,还需要考虑到更多的细节和安全问题,比如防止SQL注入、XSS攻击等。

相关推荐

为何越来越多的编程语言使用JSON(为什么编程)

JSON是JavascriptObjectNotation的缩写,意思是Javascript对象表示法,是一种易于人类阅读和对编程友好的文本数据传递方法,是JavaScript语言规范定义的一个子...

何时在数据库中使用 JSON(数据库用json格式存储)

在本文中,您将了解何时应考虑将JSON数据类型添加到表中以及何时应避免使用它们。每天?分享?最新?软件?开发?,Devops,敏捷?,测试?以及?项目?管理?最新?,最热门?的?文章?,每天?花?...

MySQL 从零开始:05 数据类型(mysql数据类型有哪些,并举例)

前面的讲解中已经接触到了表的创建,表的创建是对字段的声明,比如:上述语句声明了字段的名称、类型、所占空间、默认值和是否可以为空等信息。其中的int、varchar、char和decimal都...

JSON对象花样进阶(json格式对象)

一、引言在现代Web开发中,JSON(JavaScriptObjectNotation)已经成为数据交换的标准格式。无论是从前端向后端发送数据,还是从后端接收数据,JSON都是不可或缺的一部分。...

深入理解 JSON 和 Form-data(json和formdata提交区别)

在讨论现代网络开发与API设计的语境下,理解客户端和服务器间如何有效且可靠地交换数据变得尤为关键。这里,特别值得关注的是两种主流数据格式:...

JSON 语法(json 语法 priority)

JSON语法是JavaScript语法的子集。JSON语法规则JSON语法是JavaScript对象表示法语法的子集。数据在名称/值对中数据由逗号分隔花括号保存对象方括号保存数组JS...

JSON语法详解(json的语法规则)

JSON语法规则JSON语法是JavaScript对象表示法语法的子集。数据在名称/值对中数据由逗号分隔大括号保存对象中括号保存数组注意:json的key是字符串,且必须是双引号,不能是单引号...

MySQL JSON数据类型操作(mysql的json)

概述mysql自5.7.8版本开始,就支持了json结构的数据存储和查询,这表明了mysql也在不断的学习和增加nosql数据库的有点。但mysql毕竟是关系型数据库,在处理json这种非结构化的数据...

JSON的数据模式(json数据格式示例)

像XML模式一样,JSON数据格式也有Schema,这是一个基于JSON格式的规范。JSON模式也以JSON格式编写。它用于验证JSON数据。JSON模式示例以下代码显示了基本的JSON模式。{"...

前端学习——JSON格式详解(后端json格式)

JSON(JavaScriptObjectNotation)是一种轻量级的数据交换格式。易于人阅读和编写。同时也易于机器解析和生成。它基于JavaScriptProgrammingLa...

什么是 JSON:详解 JSON 及其优势(什么叫json)

现在程序员还有谁不知道JSON吗?无论对于前端还是后端,JSON都是一种常见的数据格式。那么JSON到底是什么呢?JSON的定义...

PostgreSQL JSON 类型:处理结构化数据

PostgreSQL提供JSON类型,以存储结构化数据。JSON是一种开放的数据格式,可用于存储各种类型的值。什么是JSON类型?JSON类型表示JSON(JavaScriptO...

JavaScript:JSON、三种包装类(javascript 包)

JOSN:我们希望可以将一个对象在不同的语言中进行传递,以达到通信的目的,最佳方式就是将一个对象转换为字符串的形式JSON(JavaScriptObjectNotation)-JS的对象表示法...

Python数据分析 只要1分钟 教你玩转JSON 全程干货

Json简介:Json,全名JavaScriptObjectNotation,JSON(JavaScriptObjectNotation(记号、标记))是一种轻量级的数据交换格式。它基于J...

比较一下JSON与XML两种数据格式?(json和xml哪个好)

JSON(JavaScriptObjectNotation)和XML(eXtensibleMarkupLanguage)是在日常开发中比较常用的两种数据格式,它们主要的作用就是用来进行数据的传...

取消回复欢迎 发表评论:

请填写验证码