0

0

php代码示例如何实现表单防重复提交_php防重复提交代码示例【示例】

絕刀狂花

絕刀狂花

发布时间:2026-01-28 15:09:09

|

412人浏览过

|

来源于php中文网

原创

最有效防重复提交需四层联动:1.前端按钮禁用+置灰;2.服务端session时间戳限频;3.一次性token校验并销毁;4.数据库唯一索引兜底。缺一不可。

php代码示例如何实现表单防重复提交_php防重复提交代码示例【示例】

session + 时间戳判断是否重复提交

用户快速连点提交按钮,或刷新页面后重发表单,最常见也最易实现的拦截方式就是靠服务端记录「上一次提交时间」。PHP 中用 $_SESSION 存一个时间戳,每次提交前比对间隔是否小于阈值(比如 2 秒):

session_start();
if (isset($_SESSION['last_submit_time']) && time() - $_SESSION['last_submit_time'] < 2) {
    die('提交过于频繁,请稍后再试');
}
$_SESSION['last_submit_time'] = time();

注意点:

  • 必须在 session_start() 后立即执行,否则 $_SESSION 不可用
  • 这个方案对同一浏览器有效,但无法防多标签/多窗口并发提交
  • 如果用户禁用 Cookie 或未维持 session,会失效

用一次性 token 防 CSRF 和重复提交

更可靠的做法是生成唯一 token,嵌入表单并存入 session,提交时校验且立即销毁。这是兼顾安全性与幂等性的标准做法:

session_start();
if (empty($_SESSION['form_token'])) {
    $_SESSION['form_token'] = bin2hex(random_bytes(16));
}
$token = $_SESSION['form_token'];

HTML 表单中加隐藏域:

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


接收时验证并清空:

session_start();
if (!isset($_POST['token']) || $_POST['token'] !== $_SESSION['form_token']) {
    die('非法请求或重复提交');
}
unset($_SESSION['form_token']); // 关键:用完即焚

常见坑:

  • 没调用 unset($_SESSION['form_token']) 就返回成功,会导致后续合法提交失败
  • 没对 $tokenhtmlspecialchars() 输出,可能引发 XSS
  • md5(time()) 这类可预测值当 token,容易被绕过

前端配合:按钮置灰 + 禁用重复点击

后端防不住所有情况,前端要第一时间阻断二次点击。关键不是靠 CSS 样式遮罩,而是真正禁用提交动作:

Getimg.ai
Getimg.ai

getimg.ai是一套神奇的ai工具。生成大规模的原始图像

下载

注意:

  • 仅靠 btn.disabled = true 不够——用户刷新页面后仍可再点,必须和服务端 token 机制联动
  • 不要用 setTimeout 延迟恢复按钮,万一后端卡住,用户会以为没提交成功而狂点
  • 如果用了 AJAX 提交,记得在 fetchaxiosfinally 里恢复按钮状态

数据库层加唯一约束兜底

即使前后端都做了防护,极端情况下(如网络超时导致用户误以为失败而重试),最终落地数据仍可能重复。这时靠数据库唯一索引是最硬的防线:

例如用户注册场景,要求 email 字段唯一:

ALTER TABLE users ADD UNIQUE KEY uk_email (email);

PHP 插入时捕获异常:

try {
    $pdo->prepare("INSERT INTO users (email, name) VALUES (?, ?)")->execute([$email, $name]);
} catch (PDOException $e) {
    if ($e->getCode() == 23000) { // MySQL 唯一键冲突错误码
        die('该邮箱已被注册');
    }
    throw $e;
}

这步常被跳过,但它才是真正防止脏数据入库的最后一道闸。尤其在分布式或高并发写入时,光靠应用层锁或 token 很难 100% 覆盖。

token 生效范围、session 生命周期、前端禁用时机、数据库约束粒度——这几个点稍有错位,重复提交就可能漏网。别只盯着一个环节使劲。

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

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

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
什么是分布式
什么是分布式

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

328

2023.08.11

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

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

235

2023.10.07

ajax教程
ajax教程

php中文网为大家带来ajax教程合集,Ajax是一种用于创建快速动态网页的技术。通过在后台与服务器进行少量数据交换,Ajax可以使网页实现异步更新。这意味着可以在不重新加载整个网页的情况下,对网页的某部分进行更新。php中文网还为大家带来ajax的相关下载资源、相关课程以及相关文章等内容,供大家免费下载使用。

159

2023.06.14

ajax中文乱码解决方法
ajax中文乱码解决方法

ajax中文乱码解决方法有设置请求头部的字符编码、在服务器端设置响应头部的字符编码和使用encodeURIComponent对中文进行编码。本专题为大家提供ajax中文乱码相关的文章、下载、课程内容,供大家免费下载体验。

160

2023.08.31

ajax传递中文乱码怎么办
ajax传递中文乱码怎么办

ajax传递中文乱码的解决办法:1、设置统一的编码方式;2、服务器端编码;3、客户端解码;4、设置HTTP响应头;5、使用JSON格式。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

117

2023.11.15

ajax网站有哪些
ajax网站有哪些

使用ajax的网站有谷歌、维基百科、脸书、纽约时报、亚马逊、stackoverflow、twitter、hacker news、shopify和basecamp等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

234

2024.09.24

cookie
cookie

Cookie 是一种在用户计算机上存储小型文本文件的技术,用于在用户与网站进行交互时收集和存储有关用户的信息。当用户访问一个网站时,网站会将一个包含特定信息的 Cookie 文件发送到用户的浏览器,浏览器会将该 Cookie 存储在用户的计算机上。之后,当用户再次访问该网站时,浏览器会向服务器发送 Cookie,服务器可以根据 Cookie 中的信息来识别用户、跟踪用户行为等。

6427

2023.06.30

document.cookie获取不到怎么解决
document.cookie获取不到怎么解决

document.cookie获取不到的解决办法:1、浏览器的隐私设置;2、Same-origin policy;3、HTTPOnly Cookie;4、JavaScript代码错误;5、Cookie不存在或过期等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

347

2023.11.23

俄罗斯Yandex引擎入口
俄罗斯Yandex引擎入口

2026年俄罗斯Yandex搜索引擎最新入口汇总,涵盖免登录、多语言支持、无广告视频播放及本地化服务等核心功能。阅读专题下面的文章了解更多详细内容。

134

2026.01.28

热门下载

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

精品课程

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

共48课时 | 1.9万人学习

MySQL 初学入门(mosh老师)
MySQL 初学入门(mosh老师)

共3课时 | 0.3万人学习

简单聊聊mysql8与网络通信
简单聊聊mysql8与网络通信

共1课时 | 812人学习

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

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