当前位置:主页 > 聚焦 >

PHP+JavaScript实现刷新继续保持倒计时的按钮

时间:2020-11-03 16:36:26

  

场景:发送一个验证码到手机,当验证码发出时,会提示隔 1 分钟之后可以再次发送。通常有这几种方式防止恶意请求,一是再次发送之前需要输入验证码,二是在指定的时间间隔之内不能再次发送。
 

  

:《PHP视频教程》

  有些网站在 1 分钟的间隔之间之内发送按钮的确是禁用了,但是只要刷新浏览器,或者通过 F12 工具修改 Button 的 disabled 属性,在时间间隔之内仍然可以点击按钮。

  需要在刷新的情况下仍然保持倒计时,可以在服务器端用过 SESSION 记录点击的时间,并且每次加载页面的时候都去检测当前时间和点击时间的时间差。

  测试框架使用 ThinkPHP 3.2.3

  视图文件位于:/Application/Home/View/Mail/index.html

  控制器位于:/Application/Home/Controller/MailController.class.php

  index.html:

  <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Document</title> <script src="发送验证码" id="send"> </body> <script> $i = 30; // 倒计时的秒数 // 检测剩余时间 $(function(){ $.ajax({ url: "{:U('Home/Mail/send_time', '', '')}", method: 'post', data: { 'seconds': $i }, success: function(data) { console.log(data); if(data > 0) { interval(data); } } }); }); // 发送点击时间 $("#send").click(function(){ $.ajax({ url: "{:U('Home/Mail/record_time', '', '')}", method: 'post', data: { 'seconds': $i, 'click_time': parseInt(new Date().getTime()/1000) }, success: function(data) { if(data != 0) { // 防止通过 F12 修改 button 的 disabled 属性在间隔时间之内再次点击按钮 interval($i); } console.log(data); } }); }); // 显示提示文字,禁用提交按钮 function setTime($t) { $button = $("#send"); $message = $("<span id='message'> <span id='wait'>"+ $t +"</span>秒后可重新发送验证码ertAfter($button); $button.attr("disabled", true); } // 倒计时 function interval($t) { setTime($t); var wait = document.getElementById('wait'); var interval = setInterval(function(){ var time = --wait.innerHTML; if(time <= 0) { clearInterval(interval); $button.attr("disabled", false); $message.remove(); }; }, 1000); } </script> </html>

   MailController.class.php:

  <?php namespace Home\\\\Controller; use Think\\\\Controller; class MailController extends Controller { public function index() { $this->display(); } // 记录时间戳 public function record_time() { session_start(); if(IS_AJAX) { $click_time = $_POST['click_time']; if(isset($_SESSION['click_time']) && $click_time - $_SESSION['click_time'] < $_POST['seconds']) { echo 0; // 防止通过 F12 修改 button 的 disabled 属性在间隔时间之内再次点击按钮 } else { $_SESSION['click_time'] = $click_time; echo date('Y-m-d H:i:s', $click_time); } } } // 发送时间戳 public function send_time() { session_start(); $time_diff = time() - $_SESSION['click_time']; if(isset($_SESSION['click_time']) && $time_diff < 30) { $diff = $_POST['seconds'] - $time_diff; if($diff > 0) { echo $_POST['seconds'] - $time_diff; } else { echo 0; } } else { unset($_SESSION['click_time']); } } }

  实现效果图

  初始状态:

   点击按钮:

  console 中显示的时间戳是点击按钮时的时间戳,通过 AJAX 发送到服务器端并且记录在 SESSION 中

  倒计时结束之前刷新页面:

  console 控制台显示的 12 表示距离倒计时结束还有 12 秒,通过加载页面时的 AJAX 请求服务器,比较当前时间和 SESSION 中记录的点击时间(如果有)并且两者相差的时间小于倒计时的时间,则返回剩余的时间,客户端接受到时间后仍然保持按钮禁用,同时从返回的时间开始倒计时。

  倒计时结束:

  按钮恢复可用。

  在倒计时间隔时间内通过 F12 删除 button 的 disabled 属性,虽然按钮可以点击,但是由于返回值是 0,因此不会触发新的动作以及重新计时:

   删除属性之前:

热点推荐
1 正在为未来几小时可能针对以色列的火力

消息,以色列军方:正在为未来几小时可能针对以色列的火力做准备;已为防御和进攻情景做...

2 美媒:以色列“企图破坏”美伊协议

消息,美国福克斯新闻网14日援引一名参与美国同伊朗谈判的外交官员的话说,以色列当天对黎...

3 Binance Wallet开启Katana第五季活动

消息,Binance Wallet宣布,Katana第五季活动将于2026年6月15日08:00正式开启,奖励池为1500万枚KAT。...

4 伊朗:以色列袭击黎巴嫩使得伊美对话“

消息,伊朗议会议长卡利巴夫14日在社交媒体发文表示,以色列对黎巴嫩首都贝鲁特南郊的袭击...

5 Solana价格预测:SOL测试70美元,牛市重拾

消息,Solana正在测试70美元的阻力位,分析师们正在评估其恢复的强度及FOMC会议的潜在影响。...

6 币安取消SpaceX IPO代币活动,向参与者空投

消息,币安已取消其SpaceX IPO代币活动,并向所有用户退款。同时,币安将向参与者空投价值...

7 bit关联地址向Binance存入280万枚Aster,价值

消息,据onchainlens监测,bit关联地址向Binance存入280万枚Aster,按实时价格计算价值约177万美元。...

8 比特币挖矿难度下降10.09%,创11大降幅

消息,比特币挖矿难度刚刚经历了历史上第11大降幅,下降幅度为10.09%。这一调整发生在区块...

9 Coinbase在HyperEVM完成43.97亿USDC转账

消息,Aakash Gupta发文称,Coinbase在HyperEVM完成约43.97亿USDC转账,资金通过单一区块结算,确认时...

10 新西兰过去一年欺诈损失1.6亿美元,加密

新西兰过去一年因欺诈犯罪造成的经济损失约为1.6亿美元,其中熟人诈骗损失约1900万美元。加...

成都来彰科技 蜀ICP备2025134723号-1

资讯来源互联网,如有版权问题请联系管理员删除。