恶意刷新

恶意刷新就是不停的去刷新提交页面,导致出现大量无效数据,这类问题在实际应用中我们经常遇到,比如一个活动的分享得积分,刷票,刷红包等等,遇到这些问题,你是如何去防止的。
当你在做一个刷红包的活动,或者一个分享得积分的活动时,频繁的被刷新会导致数据库吃紧,严重时会导致系统死机。遇到这方面你是如何防止恶意刷新页面的,说白了也就是恶意刷新你创建的链接。

下面我们来看看防止恶意刷页面的原理:

1 要求在页面间传递一个验证字符串;
2 在生成页面的时候 随机产生一个字符串;
3 做为一个必须参数在所有连接中传递。同时将这个字符串保存在session中;
点连接或者表单进入页面后,判断session中的验证码是不是与用户提交的相同,如果相同,则处理,不相同则认为是重复刷新;
4 在处理完成后将重新生成一个验证码,用于新页面的生成。我们可以从session方面防止用户恶意刷新。代码如下:方案一:

<?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;
}
?>

方案二:

<?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();
}
?>

方案三:

<?php
session_start();
if(!empty($_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的验证,假设你在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">

你也可以结合cookie与session一起用,代码如下:利用文件存储数据

<?php$c_file="counter.txt"; //文件名赋值给变量//如果文件不存在的操作if(!file_exists($c_file)) {$myfile=fopen($c_file,"w"); //创建文件fwrite($myfile,"0"); //置入“0”fclose($myfile); //关闭文件}$t_num=file($c_file); //把文件内容读入变量if($_COOKIE["date"]!="date(Y年m月d日)"){ //判断COOKIE内容与当前日期是否一致$t_num[0]++; //原始数据自增1$myfile=fopen($c_file,"w"); //写入方式打开文件fwrite($myfile,$t_num[0]); //写入新数值fclose($myfile); //关闭文件//重新将当前日期写入COOKIE并设定COOKIE的有效期为24小时setcookie("date","date(Y年m月d日)",time()+60*60*24);}
?>

这里读取数据

<?php//使用文本存储数据if($_SESSION[temp]==""){if(($fp=fopen("counter.txt","r"))==false){echo "打开文件失败!";}else{//读取文件中数据$counter=fgets($fp,1024);//关闭文本文件fclose($fp);//计数器增加1$counter++;//以写的方式打开文本文件$fp=fopen("counter.txt","w");//将新的统计数据增加1fputs($fp,$counter);fclose($fp);}//从文本文件中读取统计数据if(($fp=fopen("counter.txt","r"))==false){echo "打开文件失败!";}else{$counter=fgets($fp,1024);fclose($fp);//输出访问次数echo "数字计数器: " .$counter ;}//登录以后,$_SESSION[temp]的值不为空,给$_SESSION[temp]赋一个1$_SESSION[temp]=1;}else{echo "<script>alert("您不可以刷新本页!!");history.back();</script>";}
?>

其中counter.txt 文件为同目录下的记录登录数文件。$counter=fgets($fp,1024); 为读取文件中数值型值的方法(可包含小数点数值)

以上内容希望帮助到大家,很多PHPer在进阶的时候总会遇到一些问题和瓶颈,业务代码写多了没有方向感,不知道该从那里入手去提升,对此我整理了一些资料,包括但不限于:分布式架构、高可扩展、高性能、高并发、服务器性能调优、TP6,laravel,YII2,Redis,Swoole、Swoft、Kafka、Mysql优化、shell脚本、Docker、微服务、Nginx等多个知识点高级进阶干货需要的可以免费分享给大家,需要请戳这里链接 或 者关注咱们下面的知乎专栏

PHP架构师圈子​zhuanlan.zhihu.com

进入页面先刷新一次_转盘抽奖分享得积分,防止页面被恶意相关推荐

  1. 内网通修改积分文件_转盘抽奖分享得积分,你是如何防止页面被恶意刷新的

    恶意刷新 恶意刷新就是不停的去刷新提交页面,导致出现大量无效数据,这类问题在实际应用中我们经常遇到,比如一个活动的分享得积分,刷票,刷红包等等,遇到这些问题,你是如何去防止的. 当你在做一个刷红包的活 ...

  2. 如何将单页面转化成手机版_【Mac分享】全套Adobe for mac(pojie版)

    点击蓝字,关注我们 点文末[在看]我可谢谢您嘞 不废话上干货!!! 下载链接复制到浏览器开始下载! 红色链接可使用我们提供的不限速迅雷加速下载 Adobe Photoshop For Mac V202 ...

  3. jquery 当页面图片加载之后_在浏览器地址栏输入地址到页面渲染完成发生了什么?(下)...

    上一篇讲了前三步,本篇从第四步开始.下面是正文: 四.进行tcp三次握手,建立tcp连接. 简述一下,第三步我们找到了目标ip,并获得了服务器ip的mac地址.此时浏览器就会请求和服务器连接,用来传输 ...

  4. java 新窗口跳转页面_Java web开发中页面跳转小技巧——跳转后新页面在新窗口打开...

    最近学习Java web,在学习过程中想实现一个需求,就是在jsp页面跳转的时候,希望跳转后的新页面在新窗口中打开, 而不是覆盖原来的页面,这个需求使我困惑了好长时间,后来通过大海捞针似的在网上寻找方 ...

  5. 微信php开发 抽奖,微信(weixin)大转盘抽奖页面、数据库以及抽奖算法(PHP源码......

    在做http://www.111cn.net/list-271/的过程中用到了微信抽奖,看了其他的作者都只是吧微信抽奖的页面共享出来了.作者现在把转盘抽奖程序和微信抽奖页面都共享出来,有需要的自己把两 ...

  6. 页面转发后文本显示???_使用Divi的滑动动画显示过程的进度

    欢迎来到这个由6章组成的系列的第3章,它将教你如何使用Divi的新"动画"选项设计出色的页面板块.我将向你介绍如何构建实时演示页面的不同部分,以向你展示向网站添加动画的技术.动画功 ...

  7. js后退页面不重新加载_快应用:支持加载单独JS文件的规范思考

    当前快应用的项目中,支持加载其它JS文件(通过:require('./foo.js')),然后通过webpack工具处理依赖,最终完成页面JS的构建,其中页面JS包含了引入的所有JS内容: 本文讨论的 ...

  8. 为什么自己编写的页面总是在那里抖动_SEO排名,为什么旧页面比新内容排名高?...

    在SEO日常工作中,我们经常遇到这样一种现象,那就是旧的页面排名总是比新的页面排名要好.这为SEO人员的工作带来了诸多挑战,而实际上它是由于多种因素产生的,不能一概而论之. https://www.b ...

  9. java 重定向到某个页面并弹出消息_前端面试100问之浏览器从输入URL到页面展示发生了什么...

    点击蓝字,关注我们 『浏览器从输入URL到页面渲染发生了什么』作为一个经典题目,在前端面试中高频出现,很多大厂的面试都会从这个面试题出发,考察候选人对知识的掌握程度,这其中涉及到了网络.操作系统.We ...

最新文章

  1. linux网络虚拟化
  2. 关于学习tf.random.normal()和tf.random.uniform()的一点小总结
  3. 【趋势】未来十年计算机体系结构的历史和趋势
  4. UVa 11059 - Maximum Product
  5. maven 如何看jar是否被修改_如何在线修改jar文件
  6. Ubuntu上安装TensorFlow(python2.7版)
  7. crontab/ntpdate——时间同步
  8. What is the difference between “def” and “val” to define a function
  9. LLVM4更新--简化对象定义
  10. 从Xamarin.Essentials谈Xamarin库的封装
  11. 16 Managing Undo
  12. 我的世界如何安装java环境变量_JDK安装与环境变量配置方法
  13. 绿色版Mysql数据库快速搭建
  14. java poi word 表格 重复_java使用poi操作word, 支持动态的行(一个占位符插入多条)和表格中动态行, 支持图片...
  15. python爬取微信公众号文章
  16. MFC使用OpenCV两种版本实现mp4文件的播放
  17. 软件设计师教程(十三)计算机系统知识-软件系统分析与设计
  18. lightgbm调参经验
  19. linux脚本一般放在哪个目录下,Linux Deepin 将脚本放在个人目录下直接执行
  20. 内外网双网卡路由配置

热门文章

  1. java集合框架综述
  2. SpringBoot @Async Example
  3. Tensorflow nmt源码解析
  4. Service 之间如何通信?- 每天5分钟玩转 Docker 容器技术(101)
  5. ASP.NET弹出模态对话框
  6. Android性能调优篇之探索JVM内存分配
  7. 轻量函数式 JavaScript:八、列表操作
  8. 中国二维码应用被国外标准垄断 信息安全问题频发
  9. Shark0.9.1安装
  10. php如何获取select multiple的值