0

0

HTML表单如何验证表单Token_HTML表单验证表单Token方法【指南】

絕刀狂花

絕刀狂花

发布时间:2026-03-09 11:05:59

|

600人浏览过

|

来源于php中文网

原创

在html表单中添加csrf token需后端动态注入隐藏字段,每次请求刷新,ajax提交时需手动获取并传入body或header,后端校验须恒定时间比对且统一错误提示。

html表单如何验证表单token_html表单验证表单token方法【指南】

怎么在 HTML 表单里加 CSRF Token

直接在 <form></form> 里塞一个隐藏字段,值从后端动态注入。不是前端自己生成,也不是写死,否则毫无防护意义。

  • 后端渲染页面时,把 Token(比如从 session 或 JWT 中取)填进 <input type="hidden" name="csrf_token" value="xxx">
  • Token 必须每次请求都刷新(至少在登录、敏感操作前),不能长期复用
  • 别用 localStoragecookie 自动带的值来替代表单字段——浏览器不会自动提交它们到 <form></form> 的 POST body 里

后端怎么校验表单里的 Token

收到 POST 请求后,先读 csrf_token 字段值,再和当前用户会话中存储的 Token 比对。不一致就立刻拒绝,返回 403 Forbidden

  • 比对必须是恒定时间的(如用 hmac.compare_digest()),防止时序攻击
  • 校验失败时,不要透露“Token 过期”还是“Token 不存在”,统一返回模糊错误
  • 如果用了框架(如 Django、Flask-WTF、Spring Security),优先走内置机制,别自己拼逻辑——CSRF_TOKEN 名字、存储位置、过期策略都可能有隐式约定

Ajax 提交表单时 Token 怎么传

XMLHttpRequest 或 fetch() 不会自动带上表单里的隐藏字段,得手动提取并附在请求体或 header 里。

科大讯飞-AI虚拟主播
科大讯飞-AI虚拟主播

科大讯飞推出的移动互联网智能交互平台,为开发者免费提供:涵盖语音能力增强型SDK,一站式人机智能语音交互解决方案,专业全面的移动应用分析;

下载
  • 从 DOM 里取值:document.querySelector('input[name="csrf_token"]').value
  • POST JSON 时,把 Token 放进 body:{ "data": "...", "csrf_token": "xxx" }
  • 或者放 header:headers: { 'X-CSRF-Token': token }(后端需对应读 header)
  • 注意:如果后端同时支持表单提交和 Ajax,Token 存储方式要一致(比如都从 session 取),否则容易出现“表单能过、Ajax 失败”

为什么 Token 验证总失败

90% 是因为生命周期没对齐,而不是代码写错。

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

  • 页面加载时生成的 Token,被用户开多个标签页反复刷新,旧页面的 Token 还在表单里,但服务端已更新——导致“明明刚打开的页面却报错”
  • 后端用了分布式 session 但没共享 Token 存储(比如 Redis 没配对),A 机器生成,B 机器校验,查不到
  • 前端用了 PWA 或 Service Worker 缓存了旧 HTML,表单里还是上一轮的 Token
  • 表单 action 地址写成绝对路径但跨域了,浏览器发起预检请求(OPTIONS),而预检不带表单数据,后端没做放行,整个请求卡住

Token 校验本身很简单,难的是让前后端对“这个 Token 什么时候有效、在哪儿找、谁负责刷新”有一致预期。细节松动一点,整个防护就形同虚设。

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
spring框架介绍
spring框架介绍

本专题整合了spring框架相关内容,想了解更多详细内容,请阅读专题下面的文章。

154

2025.08.06

Java Spring Security 与认证授权
Java Spring Security 与认证授权

本专题系统讲解 Java Spring Security 框架在认证与授权中的应用,涵盖用户身份验证、权限控制、JWT与OAuth2实现、跨站请求伪造(CSRF)防护、会话管理与安全漏洞防范。通过实际项目案例,帮助学习者掌握如何 使用 Spring Security 实现高安全性认证与授权机制,提升 Web 应用的安全性与用户数据保护。

88

2026.01.26

Python Web 框架 Django 深度开发
Python Web 框架 Django 深度开发

本专题系统讲解 Python Django 框架的核心功能与进阶开发技巧,包括 Django 项目结构、数据库模型与迁移、视图与模板渲染、表单与认证管理、RESTful API 开发、Django 中间件与缓存优化、部署与性能调优。通过实战案例,帮助学习者掌握 使用 Django 快速构建功能全面的 Web 应用与全栈开发能力。

161

2026.02.04

Python Flask框架
Python Flask框架

本专题专注于 Python 轻量级 Web 框架 Flask 的学习与实战,内容涵盖路由与视图、模板渲染、表单处理、数据库集成、用户认证以及RESTful API 开发。通过博客系统、任务管理工具与微服务接口等项目实战,帮助学员掌握 Flask 在快速构建小型到中型 Web 应用中的核心技能。

103

2025.08.25

Python Flask Web框架与API开发
Python Flask Web框架与API开发

本专题系统介绍 Python Flask Web框架的基础与进阶应用,包括Flask路由、请求与响应、模板渲染、表单处理、安全性加固、数据库集成(SQLAlchemy)、以及使用Flask构建 RESTful API 服务。通过多个实战项目,帮助学习者掌握使用 Flask 开发高效、可扩展的 Web 应用与 API。

81

2025.12.15

什么是分布式
什么是分布式

分布式是一种计算和数据处理的方式,将计算任务或数据分散到多个计算机或节点中进行处理。本专题为大家提供分布式相关的文章、下载、课程内容,供大家免费下载体验。

404

2023.08.11

分布式和微服务的区别
分布式和微服务的区别

分布式和微服务的区别在定义和概念、设计思想、粒度和复杂性、服务边界和自治性、技术栈和部署方式等。本专题为大家提供分布式和微服务相关的文章、下载、课程内容,供大家免费下载体验。

250

2023.10.07

json数据格式
json数据格式

JSON是一种轻量级的数据交换格式。本专题为大家带来json数据格式相关文章,帮助大家解决问题。

454

2023.08.07

Kotlin Android模块化架构与组件化开发实践
Kotlin Android模块化架构与组件化开发实践

本专题围绕 Kotlin 在 Android 应用开发中的架构实践展开,重点讲解模块化设计与组件化开发的实现思路。内容包括项目模块拆分策略、公共组件封装、依赖管理优化、路由通信机制以及大型项目的工程化管理方法。通过真实项目案例分析,帮助开发者构建结构清晰、易扩展且维护成本低的 Android 应用架构体系,提升团队协作效率与项目迭代速度。

24

2026.03.09

热门下载

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

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3.5万人学习

AngularJS教程
AngularJS教程

共24课时 | 4.1万人学习

CSS教程
CSS教程

共754课时 | 41.4万人学习

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

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