PHP+JavaScript怎么弄刷新继续保持倒计时按钮-创新互联

PHP+JavaScript怎么弄刷新继续保持倒计时按钮?这个问题可能是我们日常学习或工作经常见到的。希望通过这个问题能让你收获颇深。下面是小编给大家带来的参考内容,让我们一起来看看吧!

我们提供的服务有:网站设计、网站建设、微信公众号开发、网站优化、网站认证、凤阳ssl等。为1000+企事业单位解决了网站和推广的问题。提供周到的售前咨询和贴心的售后服务,是有科学管理、有技术的凤阳网站制作公司

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


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

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

测试框架使用 ThinkPHP 3.2.3

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

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

index.html:




	
	Document
	


	


MailController.class.php:

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怎么弄刷新继续保持倒计时按钮大概了解了吗?希望文章内容对大家有所帮助。如果想了解更多相关文章内容,欢迎关注创新互联行业资讯频道。


名称栏目:PHP+JavaScript怎么弄刷新继续保持倒计时按钮-创新互联
标题来源:http://cdiso.cn/article/dichch.html

其他资讯