场景:发送一个验证码到手机,当验证码发出时,会提示隔 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:

Document

$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 = $(" "+ $t +"秒后可重新发送验证码...");

$message.insertAfter($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);

}

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,因此不会触发新的动作以及重新计时:

删除属性之前:

刷新网页倒计时 php,PHP+JavaScript实现刷新继续保持倒计时的按钮相关推荐

  1. 桌面html倒计时如何添加,JavaScript 实现Html页面倒计时效果的简单实例

    Html网页倒计时是Web开发中比较常用的功能之一,例如新站上线前的欢迎页,节日的到来,活动的计时等等,阿萌来简单介绍一个比较简单的倒计时实例. 原理嘛,很简单,就是利用设定的时间戳减去当前的时间戳, ...

  2. 快捷指令 自动刷新网页 脚本

    要自动刷新网页,你可以使用 JavaScript 脚本来实现.具体步骤如下: 打开你要刷新的网页. 在浏览器地址栏中输入 javascript: . 输入代码:location.reload(); . ...

  3. JQuery 定期刷新网页,保持登录状态Session

    前言 360极速浏览器 13.0.2206.0 (正式版本) (32 位) 操作系统 Windows 10 OS Version 1909 (Build 18363.1379) JavaScript ...

  4. 自动刷新网页,自动刷新当前页面,JS调用

    reload 方法,该方法强迫浏览器刷新当前页面. 语法:location.reload([bForceGet])                                            ...

  5. 自动刷新 html,JavaScript自动刷新页面的方法

    使用JavaScript location.reload方法刷新网页.当用户点击一个链接此代码可以自动在一个事件调用. 如果想使用鼠标点击刷新网页,可以用下面的代码:Refresh Page 要了解它 ...

  6. 关于刷新网页F5,Ctrl+F5amp;amp;Shift+F5

    F5刷新网页,重新显示当前页面内容: Ctrl+F5博客的系统使用了数据缓存技术.这虽然可以加快网页的打开速度,但却经常出错.比如留言成功再重新打开网页却可能看不到刚才的的留言内容,其原因就是IE会读 ...

  7. jsp对弹出jsp传值 和刷新网页后js仍然没有刷新的解决方法

    jsp对弹出jsp传值 和刷新网页后js仍然没有刷新的解决方法 现在 从A.jsp弹出B.jsp,B.jsp包含B.js: 要从B.js访问到A.jsp中的变量的值: 弹出JSP的代码为: $('#m ...

  8. AJAX+JavaScript无刷新检查用户名

    AJAX+JavaScript无刷新检查用户名是否可用2009-04-20 16:26   JavaScript 和 Ajax 代码 <script language="javascr ...

  9. 使用meta来刷新网页效果

    使用<meta>标签来实现网页的刷新缺陷很多,那就是无法停止. 不过很多朋友可能想要了解一下,下面就给出一个代码片段,需要的可以做一下参考. 代码实例如下: 1 <meta http ...

最新文章

  1. 协作机器人鼻祖“重生”,卷土重来的Rethink能否给行业注入一针强心剂?
  2. [原创] SQLite数据库使用清单(上)
  3. 高斯 matlab程序,高斯金字塔 matlab程序实现
  4. [leetcode]Next Greater Element
  5. 雷军微博念了几句诗 评论区疯狂猜谜
  6. 带你走进EJB--MDB
  7. VSCode每打开一次文件弹出一个git弹窗:-login -i rev-parse --show-toplevel
  8. 百万 Go TCP 连接的思考: epoll方式减少资源占用
  9. 奥维地图导入西安坐标_带了坐标的照片,要上天了
  10. Activiti添加批注(comment)信息
  11. 日语阅读-1-如何看ほう的用法
  12. Java 处理 XML 的三种主流技术及介绍
  13. listview控件在php的使用方法,VBA窗体之ListView控件的基本应用 | VBA实例教程
  14. centos刻录工具_centos u盘引导制作工具
  15. 量子计算与PKS信创体系首次融合,实现算力跨越
  16. 各点之间的最短距离——Java实现
  17. 复旦大学与国网上海共建“电力大数据实验室”
  18. android 统一推送平台,工信部实验室成立安卓统一推送联盟:推送服务将实现统一...
  19. java怎么连接sql_java怎么连接SQL Server
  20. Libxml2函数及使用方法概述

热门文章

  1. 一行代码写一个谷歌插件 —— Javascript
  2. 山区灭火机器人_超级灭火智能机器人 刀山火海都能去得 不服不行!
  3. Reprint: Serialization
  4. 这本Python 3入门书,火遍了整个编程圈
  5. 正式赛1004 打猎的故事
  6. Dijkstra算法 迪杰斯特拉算法 单源最短路径
  7. Visual LISP程序设计手册
  8. 怎么查看服务器的详细信息,裸金属服务器查看详细信息
  9. C语言如何检测鼠标的位置
  10. Unity中按钮检测鼠标状态