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

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

有些网站在 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="http://lib.sinaapp.com/js/jquery/1.9.1/jquery-1.9.1.min.js"></script>
</head>
<body>
	<input type="button" value="发送验证码" 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>秒后可重新发送验证码...</span>");
		$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);		
	}

</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']);
		}
	}
}

实现效果图

初始状态:

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

点击按钮:

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

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

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

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

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

倒计时结束:

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

按钮恢复可用。

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

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

删除属性之前:

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

关于PHP+JavaScript实现刷新继续保持倒计时的按钮的文章就分享到这,如果对你有帮助欢迎继续关注我们哦

本文来自投稿,不代表重蔚自留地立场,如若转载,请注明出处https://www.cwhello.com/41842.html

如有侵犯您的合法权益请发邮件951076433@qq.com联系删除

(0)
php学习php学习订阅用户
上一篇 2022年6月23日 16:31
下一篇 2022年6月23日 16:31

相关推荐

  • PHP8中的函数:str_contains(),字符串搜索的新方法。

    随着PHP8的发布,该语言引入了一种新的字符串搜索函数str_contains(),这个函数在字符串中搜索指定的子字符串,并返回一个布尔值来表示该字符串是否包含指定的子字符串。这个新函数提供了一种简单和快速的方式,用…

    2023年5月21日
    024
  • PHP文件下载练习

    html语言本身可以提供下载功能 格式: <a  href=’1.zip’>下载</a> html下载的缺点:   1、只能实现某几种格式的文件下载 2、暴露文件所在服务器的完整路径 我们可以使用php下载解决以上问题: php…

    2017年11月15日
    0213
  • 分享学编程的学费一般是多少网上,学习编程先学什么。

    学习编程的学费因地区、课程内容和培训机构的不同而有所差异,网上学习编程的费用相对较低,因为省去了实体教室的租金和其他开销,以下是一些关于网上学习编程学费的参考信息: 1. 免费资源:互联网上有大量的免费…

    2024年6月29日
    00
  • PHP入门指南:异步编程。

    PHP作为一门流行的脚本语言,一直以来都是Web开发的主流语言之一。在Web开发中,异步编程被越来越多地应用于网络爬虫、实时聊天、长轮询等高性能场景。本文将介绍PHP异步编程的相关知识,以便读者掌握异步编程基础…

    2023年5月22日
    02
  • 如何使用PHP实现微信小程序中的滑块功能。

    随着微信小程序的普及,其功能也越来越多样化。其中,滑块功能作为一个非常常用的组件,具有在界面上进行滑动选择、筛选等操作的作用,其在微信小程序中也不例外。本文将介绍如何使用PHP来实现微信小程序中的滑块功…

    2023年6月3日
    012
  • PHP中如何使用正则表达式进行数据验证。

    在 PHP 编程中,数据验证是一个非常重要的任务。当我们接收外部输入数据(例如用户的表单提交)时,我们需要在使用这些数据之前,对其进行验证,确保其格式正确并符合我们的要求。其中一种非常实用的验证方式就是使…

    2023年5月22日
    05
  • 详解php如何实现一个简单的图片边缘检测

    本篇文章给大家介绍一下php 实现一个简单的图片边缘检测。有一定的参考价值,有需要的朋友可以参考一下,希望对大家有所帮助。 php 实现一个简单的图片边缘检测 一个简单的图片边缘检测方法 大致步骤: 1、缩放图片…

    2023年3月29日 PHP自学教程
    01
  • (安全篇)PHP 的错误机制详解

    PHP 的错误机制也是非常复杂的,特别说明:文章的PHP版本使用5.5.32 PHP的错误级别 首先需要了解php有哪些错误。截至到php5.5,一共有16个错误级别 注意:尝试下面的代码的时候请确保打开error_log: error_reporting…

    2017年5月25日
    0296

联系我们

QQ:951076433

在线咨询:点击这里给我发消息邮件:951076433@qq.com工作时间:周一至周五,9:30-18:30,节假日休息