php防止网站被刷新的方法汇总
程序员文章站
2022-12-08 15:17:31
本文实例讲述了php防止网站被刷新的方法。分享给大家供大家参考。具体方法如下:
对于像采用wp建设的站来说,频繁的刷新会导致数据库吃紧。下面附上一段代码,防止频繁的刷新造...
本文实例讲述了php防止网站被刷新的方法。分享给大家供大家参考。具体方法如下:
对于像采用wp建设的站来说,频繁的刷新会导致数据库吃紧。下面附上一段代码,防止频繁的刷新造成的死机情况。
方法一,代码如下:
复制代码 代码如下:
<?php
session_start();
$k=$_get['k'];
$t=$_get['t'];
$allowtime = 1800;//防刷新时间
$ip = get_client_ip();
$allowt = md5($ip.$k.$t);
if(!isset($_session[$allowt]))
{
$refresh = true;
$_session[$allowt] = time();
}elseif(time() - $_session[$allowt]>$allowtime){
$refresh = true;
$_session[$allowt] = time();
}else{
$refresh = false;
}
?>
session_start();
$k=$_get['k'];
$t=$_get['t'];
$allowtime = 1800;//防刷新时间
$ip = get_client_ip();
$allowt = md5($ip.$k.$t);
if(!isset($_session[$allowt]))
{
$refresh = true;
$_session[$allowt] = time();
}elseif(time() - $_session[$allowt]>$allowtime){
$refresh = true;
$_session[$allowt] = time();
}else{
$refresh = false;
}
?>
方法二,代码如下:
复制代码 代码如下:
<?php
session_start();
$allow_sep = "2";
if (isset($_session["post_sep"]))
{
if (time() - $_session["post_sep"] < $allow_sep)
{
exit("请不要频繁刷新,休息2秒再刷新吧");
}
else
{
$_session["post_sep"] = time();
}
}
else
{
$_session["post_sep"] = time();
}
?>
session_start();
$allow_sep = "2";
if (isset($_session["post_sep"]))
{
if (time() - $_session["post_sep"] < $allow_sep)
{
exit("请不要频繁刷新,休息2秒再刷新吧");
}
else
{
$_session["post_sep"] = time();
}
}
else
{
$_session["post_sep"] = time();
}
?>
方法三,代码如下:
复制代码 代码如下:
<?php
session_start();
if(!emptyempty($_post[name])){
$data = $_post[name];
$tag = $_post[tag];
if($_session[status]==$tag){
echo $data;
}else{
echo "不允许刷新!";
}
}
$v = mt_rand(1,10000);
?>
<form method="post" name="magic" action="f5.php"><input type="hidden"
name="tag" value="<?=$v?>"><input type=text name="name"><input type="submit" value="submit">
</form>
<?php
echo $v;
$_session[status] = $v;
?>
session_start();
if(!emptyempty($_post[name])){
$data = $_post[name];
$tag = $_post[tag];
if($_session[status]==$tag){
echo $data;
}else{
echo "不允许刷新!";
}
}
$v = mt_rand(1,10000);
?>
<form method="post" name="magic" action="f5.php"><input type="hidden"
name="tag" value="<?=$v?>"><input type=text name="name"><input type="submit" value="submit">
</form>
<?php
echo $v;
$_session[status] = $v;
?>
注意:代码有了,不过要应用到wordpress还要一些其他操作.
因为上面的代码是基于 session的验证,假设你在2秒内刷新了页面,那么他会执行exit() 函数输出一条消息,并退出当前脚本,于是就不会加载下面的内容,所以这段代码最好放在header中,先让代码执行,再加载其他的东西.
如果把代码放在了footer里,结果整个页面都加载了只在最后一行输出了"请不要频繁刷新",放在header中,效果比较好,想看效果的话按两下f5 吧.
当然最好的是采用的是新建一个php文件,然后在header调用.
这样做的好处有两个:
一个是修改功能代码方便,不用每次都打开header文件,也不怕误改了其他地方的代码,二是一旦出错,可以快速修改并检查,甚至可以直接删除文件,代码如下:
复制代码 代码如下:
<?php
include('includes/forbiddencc.php');
?>
<!doctype html public "-//w3c//dtd xhtml 1.0 transitional//en" "http://www.w3.org/tr/xhtml1/dtd/xhtml1-transitional.dtd">
include('includes/forbiddencc.php');
?>
<!doctype html public "-//w3c//dtd xhtml 1.0 transitional//en" "http://www.w3.org/tr/xhtml1/dtd/xhtml1-transitional.dtd">
这里要注意下,必须调用在所有页面的最前面.
希望本文所述对大家的php程序设计有所帮助。
上一篇: 送给互联网从业者的4个建议
下一篇: 中关村同步硅谷 着力云计算与大数据发展