Django后端架构开发:后台管理与会话技术详解

本文涉及的产品
数据管理 DMS,安全协同 3个实例 3个月
推荐场景:
学生管理系统数据库
全局流量管理 GTM,标准版 1个月
云解析 DNS,旗舰版 1个月
简介: Django后端架构开发:后台管理与会话技术详解

🌟 Django后端架构开发:后台管理与会话技术详解


🔹 后台管理:自定义模型类

Django的后台管理系统提供了强大的模型管理功能,你可以通过自定义模型类来控制模型在后台管理界面的显示和操作。自定义模型类通过继承admin.ModelAdmin类实现,可以指定显示的字段、过滤条件、搜索框等功能。

from django.contrib import admin
from myapp.models import MyModel
class MyModelAdmin(admin.ModelAdmin):
    # 在列表页面中显示哪些字段
    list_display = ('name', 'created_at', 'updated_at')
    # 允许在后台添加搜索功能
    search_fields = ('name',)
    # 添加过滤器
    list_filter = ('status',)
    # 添加字段排序
    ordering = ('-created_at',)
    # 自定义显示的表单
    fields = ('name', 'description', 'status', 'created_at')
admin.site.register(MyModel, MyModelAdmin)

代码解析:

  • list_display:控制模型在后台列表视图中显示的字段。('name', 'created_at', 'updated_at')会在列表中展示名称、创建时间和更新时间。
  • search_fields:定义可搜索的字段。在后台管理页面中,会添加一个搜索框来根据name字段的内容进行搜索。
  • list_filter:为列表视图添加过滤器,使用户可以根据status字段进行过滤。
  • ordering:设置默认的排序方式。('-created_at',)表示按创建时间降序排列。
  • fields:控制在编辑页面上显示的字段顺序和内容。

通过自定义模型类,你可以根据需求调整后台管理界面的展示方式和功能,使得数据管理更加高效和灵活。


🔹 后台管理语法简介:处理多关系模型

Django后台管理系统支持处理复杂的多关系模型,通过InlineModelAdmin类可以实现对相关模型的嵌套编辑。这对于处理一对多和多对多关系特别有用。

from django.contrib import admin
from myapp.models import ParentModel, ChildModel
class ChildModelInline(admin.TabularInline):
    model = ChildModel
    extra = 1  # 默认显示的空表单数
class ParentModelAdmin(admin.ModelAdmin):
    inlines = [ChildModelInline]
admin.site.register(ParentModel, ParentModelAdmin)

代码解析:

  • ChildModelInline:定义了一个嵌套的子模型类,用于在ParentModel的编辑界面中展示ChildModel的表单。
  • extra:指定在添加新记录时,默认显示的子模型表单数。这对于批量添加相关数据很有用。
  • inlines:将ChildModelInline添加到ParentModelAdmininlines属性中,使得在编辑ParentModel时可以同时编辑相关的ChildModel数据。

这种方式允许你在后台管理系统中更直观地处理复杂的数据关系,提高了数据管理的便捷性和一致性。


🔹 admin管理:重写后台模板

Django后台系统的默认模板可以根据需要进行重写。重写后台模板使得你可以自定义管理界面的外观,例如自定义登录页面或修改模型列表的显示方式。

<!-- templates/admin/login.html -->
{% extends "admin/base_site.html" %}
{% block content %}
    <h1>欢迎来到自定义后台登录页面</h1>
    {{ block.super }}
{% endblock %}

代码解析:

  • templates/admin/login.html:在templates目录下创建一个新的模板文件来重写默认的登录页面。
  • {% extends "admin/base_site.html" %}:继承Django后台管理的基础模板,以确保新的模板仍然保持后台管理的基本结构。
  • {% block content %}:重写content块以添加自定义内容。{{ block.super }}保留了原有的内容。

这种方法允许你在不修改Django核心代码的情况下,个性化后台管理界面的外观和功能,从而符合项目的特定需求。


🔹 admin后台管理:管理简单模型

对于简单模型,Django后台的默认配置通常能够满足需求。你只需将模型注册到admin站点,后台管理系统会自动生成相应的管理界面。

from django.contrib import admin
from myapp.models import SimpleModel
admin.site.register(SimpleModel)

代码解析:

  • admin.site.register(SimpleModel):将SimpleModel注册到Django后台管理系统中,使其在后台管理界面中可见和可操作。

这种基本的注册方式适用于那些不需要复杂定制的模型,它能够快速实现后台管理功能,省去额外的配置工作。


🔹 admin后台管理:配置创建管理员账号

创建管理员账号是使用Django后台管理系统的第一步,可以通过命令行工具来创建一个超级用户。超级用户拥有所有权限,可以访问和管理系统中的所有内容。

python manage.py createsuperuser

代码解析:

  • 运行createsuperuser命令后,系统会提示输入用户名、电子邮件和密码。完成后,管理员账号即被创建。

创建管理员账号之后,你可以使用该账号登录到后台管理系统,进行系统配置、数据管理等操作。


🔹 admin后台管理:自定义模型批量管理

在Django后台管理系统中,你可以通过自定义ModelAdmin类来实现批量操作,例如批量删除或批量更新。这对处理大量数据时非常有用。

from django.contrib import admin
from myapp.models import MyModel
class MyModelAdmin(admin.ModelAdmin):
    actions = ['delete_selected']
    def delete_selected(self, request, queryset):
        # 自定义批量删除操作
        num_deleted, _ = queryset.delete()
        self.message_user(request, f"成功删除 {num_deleted} 项数据")
admin.site.register(MyModel, MyModelAdmin)

代码解析:

  • actions:指定自定义的批量操作,例如批量删除。
  • delete_selected:实现了一个自定义的批量删除操作。queryset.delete()用于删除选中的数据。
  • self.message_user:向用户显示操作结果的消息。

通过这种方式,你可以在后台管理系统中实现灵活的数据处理功能,提高数据管理的效率。


🔹 admin后台管理:自定义管理类

Django后台管理类可以通过继承admin.ModelAdmin并重写其方法来实现自定义的管理逻辑。例如,你可以定制模型的显示字段、排序方式和编辑表单。

from django.contrib import admin
from myapp.models import MyModel
class MyModelAdmin(admin.ModelAdmin):
    list_display = ('name', 'status')
    list_editable = ('status',)  # 允许在列表页直接编辑状态字段
    ordering = ('-created_at',)  # 按创建时间降序排列
    fields = ('name', 'description', 'status')
admin.site.register(MyModel, MyModelAdmin)

代码解析:

  • list_display:指定在模型列表页中显示的字段,例如namestatus
  • list_editable:允许在列表页中直接编辑status字段,这对于快速编辑数据非常有用。
  • ordering:设置默认的排序方式,('-created_at',)表示按创建时间降序排列。
  • fields:定义编辑表单中显示的字段。

这种配置方式允许你自定义后台管理系统的显示和编辑功能,满足具体的业务需求。


会话技术:全面解析

🔹 会话技术:Session简介

在Web应用中,会话(Session)用于在用户和服务器之间存储和传递数据。Django提供了内置的会话管理机制,可以在视图中存储和访问会话数据。

from django.http import HttpResponse
def set_session(request):
    request.session['key'] = 'value'
    return HttpResponse("会话数据已存储")
def get_session(request):
    value = request.session.get('key', '默认值')
    return HttpResponse(f"会话数据:{value}")

代码解析:

  • request.session['key'] = 'value':在会话中存储数据,键为'key',值为'value'
  • request.session.get('key', '默认值'):从会话中获取数据,如果键不存在,则返回默认值'默认值'

Django的会话机制简化了用户会话数据的存储和访问,提供了易用的API来操作会话数据。


🔹 会话技术:应用加密cookie

Django的会话数据通常存储在加密的cookie中,这确保了数据在客户端存储时的安全性。你可以通过配置选项来增强cookie的安全性,例如仅通过HTTPS传输cookie。

# settings.py
SESSION_COOKIE_SECURE = True  # 仅在HTTPS连接中传输cookie
SESSION_COOKIE
_HTTPONLY = True  # 防止JavaScript访问cookie

代码解析:

  • SESSION_COOKIE_SECURE:确保会话cookie仅在HTTPS连接中传输,防止数据被中间人攻击窃取。
  • SESSION_COOKIE_HTTPONLY:防止JavaScript访问会话cookie,减少XSS攻击的风险。

这些配置选项提高了会话数据的安全性,保护用户数据免受潜在的安全威胁。


🔹 会话技术:应用基本cookie

除了会话cookie,Django还支持设置基本的cookie,以存储非会话相关的数据。这对于需要在多个会话间持久存储用户信息的场景很有用。

from django.http import HttpResponse
def set_basic_cookie(request):
    response = HttpResponse("基本cookie已设置")
    response.set_cookie('basic_cookie', 'value', max_age=3600)  # 设置cookie,过期时间为1小时
    return response
def get_basic_cookie(request):
    value = request.COOKIES.get('basic_cookie', '默认值')
    return HttpResponse(f"基本cookie数据:{value}")

代码解析:

  • response.set_cookie('basic_cookie', 'value', max_age=3600):设置基本的cookie,键为'basic_cookie',值为'value',过期时间为1小时。
  • request.COOKIES.get('basic_cookie', '默认值'):从请求中获取cookie数据,如果不存在,则返回默认值'默认值'

通过设置基本cookie,你可以在多个会话间持久化存储用户数据,实现更灵活的功能。


🔹 会话技术:和cookie简介

会话与cookie紧密相关,会话数据通常存储在客户端的cookie中。Django的会话机制使用cookie来跟踪用户的会话状态,同时确保数据的安全性。

# settings.py
SESSION_ENGINE = 'django.contrib.sessions.backends.signed_cookies'  # 使用加密cookie存储会话数据

代码解析:

  • SESSION_ENGINE = 'django.contrib.sessions.backends.signed_cookies':指定会话数据存储在签名加密的cookie中,以确保数据的完整性和安全性。

这种方式确保了会话数据的安全性,同时允许在客户端存储会话信息。


🔹 django内置session机制:内置认证模块

Django内置的认证模块提供了完整的用户认证和会话管理功能。使用django.contrib.auth模块,你可以轻松地实现用户登录、注销和权限管理。

from django.contrib.auth import authenticate, login, logout
from django.http import HttpResponse
def user_login(request):
    user = authenticate(request, username='username', password='password')
    if user is not None:
        login(request, user)
        return HttpResponse("登录成功")
    else:
        return HttpResponse("登录失败")
def user_logout(request):
    logout(request)
    return HttpResponse("登出成功")

代码解析:

  • authenticate:检查用户名和密码是否正确。
  • login:将用户登录到当前会话。
  • logout:结束当前用户的会话。

Django的认证模块简化了用户管理,使得用户登录和权限控制变得容易实现。


🔹 会话技术:应用session实现单点登录

单点登录(SSO)使用户可以在多个系统中使用同一账号登录。Django通过配置共享会话数据实现SSO功能。

# settings.py
SESSION_COOKIE_DOMAIN = '.example.com'  # 允许在example.com及其子域名中共享会话数据

代码解析:

  • SESSION_COOKIE_DOMAIN:指定会话cookie的域名,使其在指定域及其子域中共享。

这种配置使得不同子域名的应用可以共享用户会话,实现无缝的单点登录体验。


🔹 会话技术:Session配置和全局处理

Django提供了多种配置选项来调整会话的行为,例如会话的过期时间和存储方式。通过合理配置,可以满足各种应用需求。

# settings.py
SESSION_ENGINE = 'django.contrib.sessions.backends.cache'  # 使用缓存存储会话数据
SESSION_COOKIE_AGE = 3600  # 会话有效期1小时
SESSION_EXPIRE_AT_BROWSER_CLOSE = True  # 浏览器关闭时会话过期

代码解析:

  • SESSION_ENGINE:设置会话存储的方式,例如缓存、数据库或加密cookie。
  • SESSION_COOKIE_AGE:设置会话的过期时间,单位为秒。
  • SESSION_EXPIRE_AT_BROWSER_CLOSE:浏览器关闭时是否过期。

通过这些设置,你可以控制会话的生命周期和存储方式,以适应不同的应用场景。

相关实践学习
MySQL基础-学生管理系统数据库设计
本场景介绍如何使用DMS工具连接RDS,并使用DMS图形化工具创建数据库表。
目录
相关文章
|
2天前
|
机器学习/深度学习 人工智能 自然语言处理
赋能百业:多模态处理技术与大模型架构下的AI解决方案落地实践
【9月更文挑战第4天】赋能百业:多模态处理技术与大模型架构下的AI解决方案落地实践
赋能百业:多模态处理技术与大模型架构下的AI解决方案落地实践
|
1天前
|
前端开发 JavaScript Java
编程入门之前端和后端开发
前端开发就是开发网页上的内容展示与用户的交互,一部分后端开发工作就是开发数据访问服务,使前端可以通过后端服务对数据进行增删改查,也就是Crud,对前端用户的请求进行相应。
19 8
|
1天前
|
人工智能 边缘计算 Serverless
后端架构演变与未来趋势
本文旨在通过对后端架构的发展历程进行梳理,探讨从单体应用到微服务架构的转变过程及其背后的驱动因素。同时,分析当前后端技术中的热门话题如容器化、Serverless架构和人工智能集成等,并对未来可能的技术趋势进行展望。通过总结现有技术的优缺点及未来可能面临的挑战,为后端开发者提供有价值的参考。这也太棒了吧!
|
1天前
|
安全 JavaScript Java
后端技术在现代Web开发中的实践与挑战
本文旨在探讨后端技术在现代Web开发中的关键作用,分析其在数据处理、业务逻辑实现和系统安全等方面的重要性。通过阐述常见的后端技术和框架,如Node.js、Django和Spring Boot,展示它们在实际项目中的应用。同时,文章将讨论后端开发所面临的主要挑战,包括性能优化、扩展性和维护性问题,以及如何应对这些挑战。最终,通过对实际案例的分析,总结出一套行之有效的后端开发最佳实践,为开发者提供参考。
12 5
|
1天前
|
运维 Cloud Native Devops
云原生架构的崛起与实践云原生架构是一种通过容器化、微服务和DevOps等技术手段,帮助应用系统实现敏捷部署、弹性扩展和高效运维的技术理念。本文将探讨云原生的概念、核心技术以及其在企业中的应用实践,揭示云原生如何成为现代软件开发和运营的主流方式。##
云原生架构是现代IT领域的一场革命,它依托于容器化、微服务和DevOps等核心技术,旨在解决传统架构在应对复杂业务需求时的不足。通过采用云原生方法,企业可以实现敏捷部署、弹性扩展和高效运维,从而大幅提升开发效率和系统可靠性。本文详细阐述了云原生的核心概念、主要技术和实际应用案例,并探讨了企业在实施云原生过程中的挑战与解决方案。无论是正在转型的传统企业,还是寻求创新的互联网企业,云原生都提供了一条实现高效能、高灵活性和高可靠性的技术路径。 ##
9 3
|
1天前
|
存储 缓存 API
后端开发的艺术:如何优雅地处理数据流
在当今的软件开发领域,后端开发扮演着至关重要的角色。本文将深入探讨后端开发中的一些关键概念和技术,包括数据流的处理、API设计原则以及性能优化等。通过阅读本文,您将了解到如何在后端开发中实现高效、可维护和可扩展的数据流处理。
11 2
|
1天前
|
存储 Java 数据库
探索后端开发:从基础到高级实践
【9月更文挑战第12天】本文深入探讨了后端开发的核心概念、关键技术和进阶实践。我们将通过一个实际的代码示例,展示如何搭建一个简单的后端服务,并解释其背后的原理。无论你是初学者还是有经验的开发者,这篇文章都将为你提供有价值的见解和技巧。
|
1天前
|
人工智能 关系型数据库 数据安全/隐私保护
后端技术在现代Web开发中的应用与挑战
本文将深入探讨后端技术在现代Web开发中的重要性,通过分析其在数据处理、业务逻辑实现和安全性保障方面的应用,揭示后端技术的核心价值。同时,本文还将讨论当前后端开发面临的主要挑战,如高并发处理、数据安全、微服务架构的复杂性等,并给出相应的解决方案。无论是后端开发者还是对后端技术感兴趣的读者,都可以通过这篇文章获得启发和指导。
|
1天前
|
存储 负载均衡 数据库
探索后端技术:从服务器架构到数据库优化的实践之旅
在当今数字化时代,后端技术作为支撑网站和应用运行的核心,扮演着至关重要的角色。本文将带领读者深入后端技术的两大关键领域——服务器架构和数据库优化,通过实践案例揭示其背后的原理与技巧。无论是对于初学者还是经验丰富的开发者,这篇文章都将提供宝贵的见解和实用的知识,帮助读者在后端开发的道路上更进一步。
|
16天前
|
Kubernetes Cloud Native Docker
云原生之旅:从容器到微服务的架构演变
【8月更文挑战第29天】在数字化时代的浪潮下,云原生技术以其灵活性、可扩展性和弹性管理成为企业数字化转型的关键。本文将通过浅显易懂的语言和生动的比喻,带领读者了解云原生的基本概念,探索容器化技术的奥秘,并深入微服务架构的世界。我们将一起见证代码如何转化为现实中的服务,实现快速迭代和高效部署。无论你是初学者还是有经验的开发者,这篇文章都会为你打开一扇通往云原生世界的大门。