首页 > 编程语言 >【黄啊码】PHP如何防止重复提交

【黄啊码】PHP如何防止重复提交

时间:2023-09-11 14:06:02浏览次数:30  
标签:防抖 重复 submit 表单 token SESSION 提交 PHP


防抖(Debounce)是一种防止重复提交的策略,它通过延迟一定时间来合并连续的操作,以确保只执行一次。

以下是几种防抖的实现方法以及对应的代码示例:

1. 前端 JavaScript 实现:
在前端使用 JavaScript 实现防抖,可以利用 setTimeout 函数来延迟执行提交操作。

function debounce(func, delay) {
    let timer;
    return function() {
        clearTimeout(timer);
        timer = setTimeout(() => {
            func.apply(this, arguments);
        }, delay);
    };
}

const submitForm = debounce(function() {
    // 在这里执行表单提交操作
}, 1000); // 延迟 1 秒执行

2. 后端 PHP 实现(使用 Session):
在后端使用 Session 可以防止重复提交。在提交之前,将一个 token 存储在 Session 中,然后在提交后验证 token 是否匹配。

session_start();

if ($_SERVER['REQUEST_METHOD'] === 'POST') {
    $token = uniqid(); // 生成唯一的 token
    $_SESSION['submit_token'] = $token;

    // 执行表单提交操作

    unset($_SESSION['submit_token']); // 清除 token
}

3. 后端 PHP 实现(使用 Token):
在每次页面加载时生成一个唯一的 Token,并将其存储在表单中。当表单提交时,验证 Token 是否匹配。

if ($_SERVER['REQUEST_METHOD'] === 'POST') {
    $submittedToken = $_POST['token'];
    $storedToken = $_SESSION['submit_token'];

    if ($submittedToken === $storedToken) {
        // 执行表单提交操作
        unset($_SESSION['submit_token']); // 清除 token
    }
}

请注意,以上代码示例是基本的防抖方法。在实际应用中,你可能需要根据业务需求进行适当的调整和扩展。同时,为了更好地防止重复提交,还可以结合使用前端和后端的方法来确保数据的安全性。

PHP 防抖(防重复提交)有哪些实现方法,这里列出10个

防抖(Debounce)是一种常用的防止重复提交的方法,它可以确保在短时间内只执行一次提交操作,以避免重复提交造成的问题。以下是10种实现防抖的方法,每种方法都附带一个简单的代码示例:

1 Session Token 防抖:
利用会话(Session)中的 token 来防止重复提交。

// 生成随机的 token
$token = md5(uniqid());

// 存储 token 到会话
$_SESSION['submit_token'] = $token;

// 在表单中嵌入 token
echo '<input type="hidden" name="submit_token" value="' . $token . '">';

// 处理表单提交时的校验
if ($_POST['submit_token'] === $_SESSION['submit_token']) {
    // 处理表单提交
    // 清除会话中的 token
    unset($_SESSION['submit_token']);
}

2 Token 防抖:
利用随机生成的 token 来防止重复提交。

$token = md5(uniqid());
echo '<input type="hidden" name="submit_token" value="' . $token . '">';

if ($_POST['submit_token'] === $token) {
    // 处理表单提交
}

3 时间戳防抖:
利用时间戳来防止在一段时间内的重复提交。

$currentTime = time();
$lastSubmitTime = $_SESSION['last_submit_time'] ?? 0;

if ($currentTime - $lastSubmitTime > 5) {
    // 处理表单提交
    $_SESSION['last_submit_time'] = $currentTime;
}

4 IP 地址防抖:
利用 IP 地址来防止相同 IP 的重复提交

$userIP = $_SERVER['REMOTE_ADDR'];
$lastSubmitIP = $_SESSION['last_submit_ip'] ?? '';

if ($userIP !== $lastSubmitIP) {
    // 处理表单提交
    $_SESSION['last_submit_ip'] = $userIP;
}

5 Cookie 防抖:
利用 Cookie 来防止在一段时间内的重复提交。

if (!isset($_COOKIE['submit_cookie'])) {
    // 处理表单提交
    setcookie('submit_cookie', 'submitted', time() + 60); // 60秒内不允许重复提交
}

6 JavaScript 防抖:
利用 JavaScript 来控制提交按钮的可点击状态,以防止重复点击。

<button id="submitBtn" οnclick="submitForm()">Submit</button>

<script>
    let submitting = false;

    function submitForm() {
        if (!submitting) {
            submitting = true;
            // 执行表单提交操作
            document.getElementById('submitBtn').disabled = true;
        }
    }
</script>

7 延时防抖:
在最后一次操作后的一段时间内,只执行一次提交操作。

if (!isset($_SESSION['submit_timer'])) {
    $_SESSION['submit_timer'] = time();
}

if (time() - $_SESSION['submit_timer'] > 10) {
    // 处理表单提交
    $_SESSION['submit_timer'] = time();
}

8 数据库唯一性约束:
利用数据库的唯一性约束来防止重复插入数据。

try {
    // 尝试插入数据,如果插入失败会抛出异常
    // 添加数据库的唯一性索引或唯一性约束以防止重复数据
} catch (Exception $e) {
    // 处理插入失败的情况
}

9 缓存防抖:
利用缓存系统来记录提交状态。

$cacheKey = 'submit_status_' . $userIP;
if (!cache_get($cacheKey)) {
    // 处理表单提交
    cache_set($cacheKey, 'submitted', 60); // 60秒内不允许重复提交
}

10验证码防抖:
要求用户输入特定的验证码来提交表单,防止恶意重复提交。

if ($_POST['captcha'] === $_SESSION['captcha_code']) {
    // 处理表单提交
    // 清除验证码,以防止多次使用同一个验证码
    unset($_SESSION['captcha_code']);
}

这些示例代码展示了不同的防抖方法,你可以根据你的需求选择适合的方法来防止重复提交。请注意,这些方法可能需要根据你的具体应用场景进行适当的调整和优化。

标签:防抖,重复,submit,表单,token,SESSION,提交,PHP
From: https://blog.51cto.com/huangama8/7435534

相关文章

  • phpcms v9标签合集
    phpcmsv9模板制作常用代码集合1.截取调用标题长度{str_cut($r[title],36,'')}2.格式化时间调用格式化时间2011-05-0611:22:33{date('Y-m-dH:i:s',$r[inputtime])}3.多栏目调用&多推荐位调用调用需求:文章范围为596061三个栏目,并且推送到了27和28两个推荐位;从第三条开始......
  • 《落实算法安全主体责任基本情况》范文,修改主体即可提交2
    在数字化时代,算法已经成为了商业竞争和创新的关键要素。然而,算法的广泛应用也引发了对其安全性和合规性的关切。《落实算法安全主体责任基本情况》作为算法备案过程中的一环,具有极高的专业性,需要企业全面考虑算法的隐私保护、数据合规、风险预防等一系列关键问题。正因如此,许多......
  • 基于webman的CMS,企业官网通用PHP后台管理系统
    2023年9月11日10:47:00仓库地址:https://gitee.com/open-php/zx-webman-website还有laravel+scui的版本目前还未开源,电商laravel版本差不多,后续在移植webman算是比较标准的php+vue的项目CMS,企业官网通用PHP后台管理系统Englishdoc框架介绍WebmanSCUI后端开发组件php8.......
  • Hive从小时表中删除重复数据
    Hive从小时分区中删除重复数据一、小时分区数据去重二、重写小时分区数据一、小时分区数据去重小时分区数据去重后,写入到hive临时表中withto_json_mapas(selectdistinct_track_id,time,distinct_id,to_json(lib)aslib,event,to_json(properties......
  • 将git的本地仓库提交到远程仓库
    #先初始化本地仓库gitinit#将所有文件添加到缓存gitadd.#将缓存文件提交给git仓库,在执行这句时,会让填写提交的介绍信息,这里和linux的vim编辑器类型gitcommit#与远程仓库建立连接,(gitremoteaddorigin+远程仓库地址)gitremoteaddoriginhttps://gitee.com/......
  • PHP是一种广泛应用于Web开发的编程语言
    PHP是一种广泛应用于Web开发的编程语言,它具有众多强大的特性和灵活的语法。在本文中,我们将深入探讨PHP的一些具体案例和例子,以帮助您更好地理解并应用它在实际项目中的强大功能。首先,让我们来看一个简单的实例,介绍PHP的核心概念之一:变量。在思密达梦三国PHP中,您可以使用$符号来......
  • 预防重复提交的开关
    这一段代码用于防止数据重复提交,如果repeatSubmit为false,那么就可以重复提交(默认是打开“不准重复提交”)来测这一段代码是后来加上的发现没有了限制,想交就交好了,测完了,记得把代码删了......
  • 就archlinux系统中apache 无法启动php的原因
    原文连接背景,在archlinux里面想使用apache作为服务器启动php服务,根据ArchWiki 的配置,并不成功检验原因:sudosystemctlstatushttpd结果:systemctlstatusapachesystemd[1]:StartedApacheWebServerhttpd[1444]:httpd:Syntaxerroronline542of/etc/httpd......
  • php实现文件上传下载功能
    文件的上传与下载是项目中必不可少的模块,也是php最基础的模块之一,大多数php框架中都封装了关于上传和下载的功能,不过对于原生的上传下载还是需要了解一下的。基本思路是通过form表单post方式实现文件上传,通过流输出的方式实现文件下载。以下分别讲述实现的具体细节。一、文件的上......
  • 优化重复冗余代码的8种方式!
    日常开发中,我们经常会遇到一些重复冗余的代码。大家都知道重复代码不好,它主要有这些缺点:可维护性差、可读性差、增加错误风险等等。最近呢,我优化了一些系统中的重复代码,用了好几种的方式,感觉挺有用的。所以本文给大家讲讲优化重复冗余代码的几种方式~抽取公用方法抽个工具类反射泛......