0

0

Python怎么防CSRF攻击_CSRF Token生成与表单验证机制

P粉602998670

P粉602998670

发布时间:2026-03-18 11:39:11

|

484人浏览过

|

来源于php中文网

原创

CSRF Token必须每次请求更换,因其重用等同于泄露门禁卡;攻击者截获后可无限伪造请求,即使session已过期。Django、Flask-WTF、FastAPI等框架默认每次生成新token,手动缓存或硬编码即失效防护。

python怎么防csrf攻击_csrf token生成与表单验证机制

CSRF Token 为什么必须每次请求都换?

因为重用 token 等同于把门禁卡借给别人用。攻击者一旦截获一次合法 csrf_token,就能反复伪造请求——哪怕用户已登出、session 过期,只要 token 没失效,攻击就有效。

Django 默认的 get_token()、Flask-WTF 的 csrf_token 字段、FastAPI + Starlette 的 CSRFProtect 中间件,都默认在每次 session 创建或调用时生成新值。但注意:如果你手动缓存了 token(比如存在全局变量或 Redis 中长期复用),就等于主动关掉防护。

  • 不要把 csrf_token 存进数据库或配置文件里长期复用
  • 不要在 AJAX 请求头里硬编码一个固定字符串当 X-CSRFToken
  • 如果用了前后端分离(如 Vue + FastAPI),token 必须从后端接口动态获取,且每次提交前重新 fetch 一次

表单里怎么塞 token 才不被绕过?

CSRF 防护只对“状态变更请求”(POST/PUT/DELETE)有意义,而 token 必须出现在服务端可验证的位置——不能只靠前端 JS 插入,也不能只放 header 里漏掉表单字段。

Django 模板中用 {% csrf_token %} 是安全的,因为它会自动绑定当前 session;Flask-WTF 的 {{ form.hidden_tag() }} 同理。但如果你手写 HTML 表单,又忘了加 <input type="hidden" name="csrf_token" value="{{ csrf_token }}">,那整个验证就形同虚设。

立即学习Python免费学习笔记(深入)”;

  • GET 请求不用传 token,但别在 GET 里做删改操作(比如 /api/user/delete?id=123
  • AJAX 提交时,既要设置 headers: {'X-CSRFToken': token},也要确保后端同时检查 header 和 body(有些框架只查 header)
  • 如果用了 CDN 或反向代理,确认它没过滤或缓存带 Set-Cookie 的响应——否则用户拿不到新 cookie,token 就对不上

为什么校验失败总报 403 Forbidden 却没提示?

这不是 bug,是设计使然。暴露具体失败原因(比如 “token 过期” 或 “token 不匹配”)会帮攻击者做差分测试,所以主流框架默认只返回 403,连日志都不打细节。

AIPURE
AIPURE

AIPURE帮您轻松找到2024年最佳AI工具

下载

调试时可以临时开启 debug 模式:Django 设置 DEBUG = True 并捕获 django.middleware.csrf.RejectRequest 异常;Flask-WTF 在 app.config['WTF_CSRF_CHECK_DEFAULT'] = True 下配合 try/except ValidationError;FastAPI 则需在 CSRFProtect 初始化时传 on_error 回调。

  • 生产环境别改错误响应体,但可以在 Nginx 日志里加 $sent_http_x_csrf_protection 这类自定义 header 辅助排查
  • 注意浏览器同站策略(SameSite)影响:如果 cookie 设了 SameSite=Lax,跨站 POST 时 cookie 不会带上,导致后端找不到 session,自然校验失败
  • 移动端 WebView 加载 H5 页面时,部分安卓系统会清空第三方 cookie,造成 token 和 session 不一致

CSRF Token 和 JWT 能混着用吗?

能,但别把两者职责搞混。JWT 是认证凭证,解决“你是谁”;CSRF Token 是防重放令牌,解决“这个请求真是你发起的吗”。把 JWT 放在 Authorization header 里,再额外在 body 或 header 里传一个独立的 csrf_token,才是正确姿势。

常见错误是直接拿 JWT 的 payload 做 CSRF 校验——比如取 exp 时间戳当 token,或者用 user_id + salt 签名生成。这会导致 token 可预测、可重放,完全失去 CSRF 防护意义。

  • CSRF Token 必须由服务端生成、绑定 session 或一次性随机数(如 secrets.token_urlsafe(32)),不能由客户端构造
  • 如果用了无状态 JWT,那就得搭配服务端存储的 token 白名单(比如 Redis 里存 jwt_jti:csrf_token 映射),否则无法注销或提前失效
  • 别为了省事把 csrf_token 塞进 JWT 的 custom claim 里传回来——它会被缓存、转发、甚至被中间人解码

最麻烦的地方往往不在生成和校验逻辑本身,而在于 cookie 的 SecureHttpOnlySameSite 三个属性怎么配,以及前端是否真按预期发送了 cookie 和 header。这些细节一错,token 就对不上,而且很难从错误信息里看出根源。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
nginx 重启
nginx 重启

nginx重启对于网站的运维来说是非常重要的,根据不同的需求,可以选择简单重启、平滑重启或定时重启等方式。本专题为大家提供nginx重启的相关的文章、下载、课程内容,供大家免费下载体验。

248

2023.07.27

nginx 配置详解
nginx 配置详解

Nginx的配置是指设置和调整Nginx服务器的行为和功能的过程。通过配置文件,可以定义虚拟主机、HTTP请求处理、反向代理、缓存和负载均衡等功能。Nginx的配置语法简洁而强大,允许管理员根据自己的需要进行灵活的调整。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

522

2023.08.04

nginx配置详解
nginx配置详解

NGINX与其他服务类似,因为它具有以特定格式编写的基于文本的配置文件。本专题为大家提供nginx配置相关的文章,大家可以免费学习。

611

2023.08.04

tomcat和nginx有哪些区别
tomcat和nginx有哪些区别

tomcat和nginx的区别:1、应用领域;2、性能;3、功能;4、配置;5、安全性;6、扩展性;7、部署复杂性;8、社区支持;9、成本;10、日志管理。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

245

2024.02.23

nginx报404怎么解决
nginx报404怎么解决

当访问 nginx 网页服务器时遇到 404 错误,表明服务器无法找到请求资源,可以通过以下步骤解决:1. 检查文件是否存在且路径正确;2. 检查文件权限并更改为 644 或 755;3. 检查 nginx 配置,确保根目录设置正确、没有冲突配置等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

760

2024.07.09

Nginx报404错误解决方法
Nginx报404错误解决方法

解决方法:只需要加上这段配置:try_files $uri $uri/ /index.html;即可。想了解更多Nginx的相关内容,可以阅读本专题下面的文章。

3621

2024.08.07

nginx部署php项目教程汇总
nginx部署php项目教程汇总

本专题整合了nginx部署php项目教程汇总,阅读专题下面的文章了解更多详细内容。

60

2026.01.13

nginx配置文件详细教程
nginx配置文件详细教程

本专题整合了nginx配置文件相关教程详细汇总,阅读专题下面的文章了解更多详细内容。

74

2026.01.13

Python WebSocket实时通信与异步服务开发实践
Python WebSocket实时通信与异步服务开发实践

本专题聚焦 Python 在实时通信场景中的开发实践,系统讲解 WebSocket 协议原理、长连接管理、消息推送机制以及异步服务架构设计。内容包括客户端与服务端通信实现、连接稳定性优化、消息队列集成及高并发处理策略。通过完整案例,帮助开发者构建高效稳定的实时通信系统,适用于聊天应用、实时数据推送等场景。

3

2026.03.18

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
最新Python教程 从入门到精通
最新Python教程 从入门到精通

共4课时 | 22.5万人学习

Django 教程
Django 教程

共28课时 | 5.1万人学习

SciPy 教程
SciPy 教程

共10课时 | 2万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号