用户名:
密 码: 记住
您当前的位置:首页 > 网络编程 > php教程

php防止网站被f5刷新的例子

时间:2015-01-23  来源:西部数据  作者:西部数据

最近比较晕了,博客经常给朋友f5不停的刷新了,这个让一个空间根据搞不定呀,后来网上整理了一些防止刷新的代码才得己解决,下面来看到整理的代码吧,希望这些例子对你有帮助.

搬家到阿里云的头两天头痛了,主机配置低,尼玛的wp的需求高,F5几下就刷死了,你让俺情何以堪,以前用过的主机配置哪有这么逊的,就不吐槽阿里云了,说不定当你看到这里的时候,这个站还在阿里云这蹲着呢.

下面附上一段代码,防止频繁的刷新导致数据库吃紧....

方式NO.1,代码如下:

  1. <?php       
  2. session_start();       
  3. $k=$_GET['k'];       
  4. $t=$_GET['t'];       
  5. $allowTime = 1800;//防刷新时间       
  6. $ip = get_client_ip();       
  7. $allowT = md5($ip.$k.$t);       
  8. if(!isset($_SESSION[$allowT]))       
  9. {       
  10.     $refresh = true;       
  11.     $_SESSION[$allowT] = time();       
  12. }elseif(time() - $_SESSION[$allowT]>$allowTime){       
  13.     $refresh = true;       
  14.     $_SESSION[$allowT] = time();       
  15. }else{       
  16.     $refresh = false;       
  17. }       
  18. ?> 

方式NO.2,代码如下:

  1. <?php 
  2. //Changed by www.phpfensi.com 
  3. session_start(); 
  4. $allow_sep = "2"
  5. if (isset($_SESSION["post_sep"])) 
  6. if (time() - $_SESSION["post_sep"] < $allow_sep
  7. exit("请不要频繁刷新,休息2秒再刷新吧"); 
  8. else 
  9. $_SESSION["post_sep"] = time(); 
  10. else 
  11. $_SESSION["post_sep"] = time(); 
  12. ?> 

方式NO.3,代码如下:

  1. <?php 
  2. session_start(); 
  3. if(!emptyempty($_POST[name])){ 
  4.    $data = $_POST[name]; 
  5.    $tag = $_POST[tag]; 
  6.    if($_SESSION[status]==$tag){ 
  7.      echo $data
  8.    }else
  9.      echo "不允许刷新!"
  10.    } 
  11. $v = mt_rand(1,10000); 
  12. ?> 
  13. <form method="post" name="magic" action="f5.php"><input type="hidden" 
  14. name="tag" value="<?=$v?>"><input type=text name="name"><input type="submit" value="submit"
  15. </form>//开源代码phpfensi.com 
  16. <?php 
  17. echo $v
  18. $_SESSION[status] = $v
  19. ?>  

有何妙用??你猜呢 呵呵 有用到的拿去吧

注意:代码有了,不过要应用到WordPress还要一些其他操作.

因为上面的代码是基于 session的验证,假设你在2秒内刷新了页面,那么他会执行exit() 函数输出一条消息,并退出当前脚本,于是就不会加载下面的内容,所以这段代码最好放在header中,先让代码执行,再加载其他的东西.

如果把代码放在了footer里,结果整个页面都加载了只在最后一行输出了“请不要频繁刷新”,放在header中,效果比较好,想看效果的话按两下F5 吧.

当然最好的是采用的是新建一个php文件,然后在header调用.

这样做的好处有两个:

一个是修改功能代码方便,不用每次都打开header文件,也不怕误改了其他地方的代码,二是一旦出错,可以快速修改并检查,甚至可以直接删除文件,代码如下:

  1. <?php  
  2. include(‘includes/forbiddenCC.php’);  
  3. ?>   
  4.     <!DOCTYPE html PUBLIC “-//W3C//DTD XHTML 1.0 Transitional//EN” “http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd”> 

这里呢要注意下,必须调用在所有页面的最前面.

来顶一下
返回首页
返回首页
推荐资讯
WiFi太不安全:7岁女孩11分钟内入侵公共网络 WiFi太不安全:7岁女孩11分钟内入侵近期刚刚发布研究说WiFi网络能获得人们手机里多少私人信息,
不服跑个分?人工智能也出现“刷分”乱象 不服跑个分?人工智能也出现“刷分2014年,人工智能领域突然爆发,成为了科研和科技创业的热门
相关文章
    无相关信息
栏目更新
栏目热门