Django核心知识点全景解析

news2025/6/8 19:17:48

引言

        本文深入剖析Django核心组件,涵盖数据交换、异步交互、状态管理及安全认证,附完整代码示例和避坑指南!

目录

引言

一、JSON:轻量级数据交换标准

1. 核心特性

2. 标准格式

3. 各语言处理方法

4. 常见错误示例

二、AJAX:异步通信核心技术

1. 核心优势

2. 原生JS实现

3. jQuery简化实现

4. 安全防护(CSRF Token)

5. 文件上传实战

三、Cookie:客户端状态管理

1. 核心原理

2. Django操作API

3. 关键参数

四、Session:服务端会话管理

1. Session配置方案

2. 核心操作方法

3. 存储引擎对比

五、分页:Paginator组件

1. 基础用法

2. 核心API说明

Paginator对象

Page对象

六、Form:表单处理利器

1. 字段类型大全

2. 自定义验证规则

3. 动态Choice技巧

总结与最佳实践


一、JSON:轻量级数据交换标准

1. 核心特性

  • 跨语言:独立于编程语言

  • 自描述性:键值对结构清晰易读

  • 轻量化:比XML节省30%以上带宽

2. 标准格式

// 对象格式
{
  "name": "rose",
  "age": 20,
  "hobby": ["reading", "travel"]
}

// 数组格式
["jack", 18, "man"]

3. 各语言处理方法

语言序列化方法反序列化方法
JavaScriptJSON.stringify()JSON.parse()
Pythonjson.dumps()json.loads()

4. 常见错误示例

// 错误1:属性名未用双引号
{ name: "张三" }  

// 错误2:使用十六进制值
[0xFFF]         

// 错误3:包含函数
{ "getData": function() {...} }

JSON vs XML:JSON结构更简洁,相同数据量下字符数减少40%,解析速度提升2倍+

二、AJAX:异步通信核心技术

1. 核心优势

  • 局部刷新:不重载整个页面

  • 异步交互:无需等待响应即可发送新请求

  • 带宽优化:仅传输必要数据

2. 原生JS实现

var xmlHttp = new XMLHttpRequest();
xmlHttp.open("POST", "/ajax_test/", true);
xmlHttp.setRequestHeader("Content-type", "application/x-www-form-urlencoded");
xmlHttp.send("username=q1mi&password=123456");
xmlHttp.onreadystatechange = function() {
  if (xmlHttp.readyState == 4 && xmlHttp.status == 200) {
    alert(xmlHttp.responseText);
  }
};

3. jQuery简化实现

<script>
$('#btn').click(function() {
  $.ajax({
    url: '/api/data/',
    type: 'post',
    data: { 
      param1: $('#input1').val(),
      param2: $('#input2').val()
    },
    success: function(res) {
      $('#result').val(res.data);
    }
  });
});
</script>

4. 安全防护(CSRF Token)

$.ajax({
  type: "POST",
  data: {
    "csrfmiddlewaretoken": $("[name='csrfmiddlewaretoken']").val(),
    // 其他数据...
  }
});

5. 文件上传实战

var formData = new FormData();
formData.append("file", $("#fileInput")[0].files[0]);
formData.append("csrfmiddlewaretoken", token);

$.ajax({
  url: "/upload/",
  type: "POST",
  processData: false,  // 禁止处理数据
  contentType: false,  // 不设置Content-Type
  data: formData
});

应用场景:搜索提示、用户名实时校验、无刷新分页

三、Cookie:客户端状态管理

1. 核心原理

graph LR
A[服务器] -->|Set-Cookie| B[浏览器]
B -->|携带Cookie| A

2. Django操作API

# 设置Cookie(加密)
response.set_signed_cookie('user', 'john', salt='secret', max_age=3600)

# 读取Cookie
request.get_signed_cookie('user', default='guest', salt='secret')

# 删除Cookie
response.delete_cookie('user')

3. 关键参数

参数说明示例值
max_age过期时间(秒)3600 (1小时)
path生效路径"/admin"
domain生效域名.example.com
httponly禁止JS访问True
secure仅HTTPS传输True

四、Session:服务端会话管理

1. Session配置方案

# settings.py
SESSION_ENGINE = 'django.contrib.sessions.backends.cached_db'  # 缓存+数据库
SESSION_COOKIE_AGE = 1209600  # 默认2周
SESSION_EXPIRE_AT_BROWSER_CLOSE = True  # 关闭浏览器即失效

2. 核心操作方法

# 存取数据
request.session['user_id'] = 42 
user_id = request.session.get('user_id')

# 会话管理
session_key = request.session.session_key  # 获取会话ID
request.session.flush()  # 删除会话及Cookie
request.session.set_expiry(300)  # 5分钟后过期

3. 存储引擎对比

引擎类型优点适用场景
数据库持久化存储高安全性需求
缓存高速读写高并发场景
文件系统无需额外服务小型应用
签名Cookie无需服务器存储无状态架构

五、分页:Paginator组件

1. 基础用法

from django.core.paginator import Paginator

def article_list(request):
    queryset = Article.objects.all()
    paginator = Paginator(queryset, 10)  # 每页10条
    
    page_number = request.GET.get('page')
    page_obj = paginator.get_page(page_number)
    
    return render(request, 'list.html', {'page_obj': page_obj})

2. 核心API说明

Paginator对象

  • num_pages:总页数

  • page_range:页码范围(如range(1, 5)

Page对象

  • object_list:当前页数据

  • has_previous():是否有上一页

  • previous_page_number():上一页页码

  • has_next():是否有下一页

  • next_page_number():下一页页码

六、Form:表单处理利器

1. 字段类型大全

字段类型说明示例
CharField文本输入name = forms.CharField()
EmailField邮箱验证自动验证@格式
ChoiceField下拉单选widget=forms.Select()
ModelChoiceField模型下拉queryset=User.objects.all()
DateTimeField日期时间input_formats=['%Y-%m-%d %H:%M']
FileField文件上传需设置enctype="multipart/form-data"

2. 自定义验证规则

class LoginForm(forms.Form):
    username = forms.CharField(
        min_length=8,
        label="用户名",
        error_messages={
            "required": "用户名不能为空",
            "min_length": "长度不能少于8个字符"
        }
    )
    password = forms.CharField(
        widget=forms.PasswordInput,
        validators=[custom_password_validator]  # 自定义验证器
    )

3. 动态Choice技巧

# 方式1:在__init__中动态赋值
class DynamicForm(forms.Form):
    def __init__(self, *args, **kwargs):
        super().__init__(*args, **kwargs)
        self.fields['city'].choices = City.objects.values_list('id', 'name')

# 方式2:使用ModelChoiceField
authors = forms.ModelChoiceField(queryset=Author.objects.filter(active=True))

总结与最佳实践

数据交换:优先使用JSON替代XML

异步通信:AJAX实现局部刷新,提升用户体验

状态管理

  • 小型数据用Cookie(最大4KB)

  • 敏感数据用Session

表单处理

  • 基础表单用Form

  • 模型关联用ModelForm

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2404467.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

WINUI——Magewell视频捕捉开发手记

背景 因需要融合视频&#xff0c;并加载患者CT中提取出的气管镜与病变&#xff0c;以便能实时查看气管镜是否在正确位置。 开发环境 硬件&#xff1a;Magewell的USB Capture HDMI Gen 2 IDE&#xff1a;VS2022 FrameWork: .Net6 WINUI Package: MVVMToolKit NLog Ma…

TDengine 开发指南——无模式写入

简介 在物联网应用中&#xff0c;为了实现自动化管理、业务分析和设备监控等多种功能&#xff0c;通常需要采集大量的数据项。然而&#xff0c;由于应用逻辑的版本升级和设备自身的硬件调整等原因&#xff0c;数据采集项可能会频繁发生变化。为了应对这种挑战&#xff0c;TDen…

第34次CCF-CSP认证真题解析(目标300分做法)

第34次CCF-CSP认证 矩阵重塑&#xff08;其一&#xff09;AC代码及解析矩阵重塑&#xff08;其二&#xff09;AC代码及解析货物调度AC代码及解析 矩阵重塑&#xff08;其一&#xff09; 输入输出及样例&#xff1a; AC代码及解析 1.线性化原矩阵 &#xff1a;由于cin的特性我们…

video-audio-extractor:视频转换为音频

软件介绍 前几天在网上看见有人分享了一个源码&#xff0c;大概就是py调用的ffmpeg来制作的。 这一次我带来源码版&#xff08;需要py环境才可以运行&#xff09;&#xff0c;开箱即用版本&#xff08;直接即可运行&#xff09; 软件特点 软件功能 视频提取音频&#xff1a…

[概率论基本概念4]什么是无偏估计

关键词&#xff1a;Unbiased Estimation 一、说明 对于无偏和有偏估计&#xff0c;需要了解其叙事背景&#xff0c;是指整体和抽样的关系&#xff0c;也就是说整体的叙事是从理论角度的&#xff0c;而估计器原理是从实践角度说事&#xff1b;为了表明概率理论&#xff08;不可…

PL/SQLDeveloper中数值类型字段查询后显示为科学计数法的处理方式

PL/SQLDeveloper中数值类型字段查询后显示为科学计数法的处理方式 文章目录 PL/SQLDeveloper中数值类型字段查询后显示为科学计数法的处理方式1. 查询效果2. 处理方式3. 再次查询 1. 查询效果 2. 处理方式 3. 再次查询

【vue】Uniapp 打包Android 文件选择上传问题详解~

需求 uniapp兼容android app&#xff0c;pc&#xff0c;h5的文件选择并上传功能。 需要支持拍照和相册选择&#xff0c;以及选择其他类型文件上传~ 实践过程和问题 开始使用uni-file-picker组件 以为很顺利&#xff0c;android模拟器测试…… 忽略了平台兼容性提示~&#…

Ctrl-Crash 助力交通安全:可控生成逼真车祸视频,防患于未然

视频扩散技术虽发展显著&#xff0c;但多数驾驶数据集事故事件少&#xff0c;难以生成逼真车祸图像&#xff0c;而提升交通安全又急需逼真可控的事故模拟。为此&#xff0c;论文提出可控车祸视频生成模型 Ctrl-Crash&#xff0c;它以边界框、碰撞类型、初始图像帧等为条件&…

网络编程之服务器模型与UDP编程

一、服务器模型 在网络通信中&#xff0c;通常要求一个服务器连接多个客户端 为了处理多个客户端的请求&#xff0c;通常有多种表现形式 1、循环服务器模型 一个服务器可以连接多个客户端&#xff0c;但同一时间只能连接并处理一个客户的请求 socket() 结构体 bind() listen() …

Transformer-BiLSTM、Transformer、CNN-BiLSTM、BiLSTM、CNN五模型时序预测

Transformer-BiLSTM、Transformer、CNN-BiLSTM、BiLSTM、CNN五模型时序预测 目录 Transformer-BiLSTM、Transformer、CNN-BiLSTM、BiLSTM、CNN五模型时序预测预测效果基本介绍程序设计参考资料 预测效果 基本介绍 Transformer-BiLSTM、Transformer、CNN-BiLSTM、BiLSTM、CNN五…

阿里云服务器安装nginx并配置前端资源路径(前后端部署到一台服务器并成功访问)

​​​运行以下命令&#xff0c;安装Nginx相关依赖。 yum install -y gcc-c yum install -y pcre pcre-devel yum install -y zlib zlib-devel yum install -y openssl openssl-devel 运行wget命令下载Nginx 1.21.6。 您可以通过Nginx开源社区直接获取对应版本的安装包URL&…

C++11新增重要标准(下)

前言 一&#xff0c;forward&#xff08;完美转发&#xff09; 二&#xff0c;可变参数模板 三&#xff0c;emplace系列接口 四&#xff0c;新增类功能 五&#xff0c;default与delete 六&#xff0c;lambda表达式 七&#xff0c;包装器 八&#xff0c;bind 在C11中新增…

【第六篇】 SpringBoot的日志基础操作

简介 日志系统在软件开发中至关重要&#xff0c;用于调试代码、记录运行信息及错误堆栈。本篇文章不仅详细介绍了日志对象的创建及快速使用&#xff0c;还说明了日志持久化的两种配置方式和滚动日志的设置。实际开发需根据场景选择合适的日志级别和存储策略。文章内容若存在错误…

Pluto论文阅读笔记

主要还是参考了这一篇论文笔记&#xff1a;https://zhuanlan.zhihu.com/p/18319150220 Pluto主要有三个创新点&#xff1a; 横向纵向用lane的query来做将轨迹投回栅格化地图&#xff0c;计算碰撞loss对数据进行正增强和负增强&#xff0c;让正增强的结果也无增强的结果相近&a…

matlab 2024a ​工具箱Aerospsce Toolbox报错​

Matlab R2024a中Aerospsce Toolbox报错 警告&#xff1a;Aerospace Toolbox and Aerospace Blockset licenses are required in ‘built-in/Spacecraft Dynamics’ 找到安装路径\MATLAB\R2024a\licenses文件夹license_****_R2024a.lic 里面工具箱名称出错&#xff0c;手动修改…

使用有限计算实现视频生成模型的高效训练

大家读完觉得有帮助记得关注和点赞&#xff01;&#xff01;&#xff01; 抽象 视频生成的最新进展需要越来越高效的训练配方&#xff0c;以减轻不断上升的计算成本。在本报告中&#xff0c;我们介绍了 ContentV&#xff0c;这是一种 8B 参数文本到视频模型&#xff0c;在 256 …

Server2003 B-1 Windows操作系统渗透

任务环境说明&#xff1a; 服务器场景&#xff1a;Server2003&#xff08;开放链接&#xff09; 服务器场景操作系统&#xff1a;Windows7 1.通过本地PC中渗透测试平台Kali对服务器场景Windows进行系统服务及版本扫描渗透测试&#xff0c;并将该操作显示结果中Telnet服务对应的…

一次Oracle的非正常关闭

数据库自己会关闭吗&#xff1f; 从现象来说Oracle MySQL Redis等都会出现进程意外停止的情况。而这些停止都是非人为正常关闭或者暴力关闭&#xff08;abort或者kill 进程&#xff09; 一次测试环境的非关闭 一般遇到这种情况先看一下错误日志吧。 2025-06-01T06:26:06.35…

YOLO11解决方案之分析

概述 Ultralytics提供了一系列的解决方案&#xff0c;利用YOLO11解决现实世界的问题&#xff0c;包括物体计数、模糊处理、热力图、安防系统、速度估计、物体追踪等多个方面的应用。 Ultralytics提供了三种基本的数据可视化类型&#xff1a;折线图&#xff08;面积图&#xf…

yolov11与双目测距结合,实现目标的识别和定位测距(onnx版本)

一、yolov11双目测距基本流程 yolov11 双目测距的大致流程就是&#xff1a; 双目标定 --> 立体校正&#xff08;含消除畸变&#xff09; --> 立体匹配 --> 视差计算 --> 深度计算(3D坐标)计算 --> 目标检测 --> 目标距离计算及可视化 下面将分别阐述每…