php防止恶意刷新与刷票的方法

前端之家收集整理的这篇文章主要介绍了php防止恶意刷新与刷票的方法前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

本文实例讲述了PHP防止恶意刷新与刷票的方法分享给大家供大家参考。具体实现方法如下:

一般来说,恶意刷新就是不停的去刷新提交页面,导致出现大量无效数据,下面我们来总结一下PHP 防止恶意刷新页面方法总结。

防止恶意刷页面的原理是:

要求在页面间传递一个验证字符串, 在生成页面的时候 随机产生一个字符串, 做为一个必须参数在所有连接中传递。同时将这个字符串保存在session中。 点连接或者表单进入页面后,判断session中的验证码是不是与用户提交的相同,如果相同,则处理,不相同则认为是重复刷新。 在处理完成后将重新生成一个验证码,用于新页面生成

PHP实现代码如下:

代码如下:
$allowTime){ $refresh = true; $_SESSION[$allowT] = time(); }else{ $refresh = false; } ?>

ie6提交两次我也碰到过,大致是用图片代替submit时,图片上有个submit(),这样会提交两次,如果只是submit钮我没碰到过提交两次的情况。 现在整理一下: 方法基本上前面几位说得差不多

接收的页即2.PHP分为两部分,一部分处理提交过来的变量,一部分显示页面 处理变量完毕用header( "location: ".$_SERVER[ 'PHP_SELF '])跳转到自身页 本部分要做判断,如果没有post的变量就跳过。当然也可以跳到别的页面。 跳到别的页面返回时会有问题,建议做在一个PHP文件里。

如果上页穿过来得变量不符合要求可以强制返回

只说了一下大体思路,也许高手们不会遇到此类问题,可是并不是每个人都是高手。

代码如下:
history.go(-1); else //操作数据 ... if(操作完成) header( "location: ".$_SERVER[ 'PHP_SELF ']); }
也可以

利用COOKIE

代码如下:

利用session:

页面文件 index.PHP 代码
代码如下:
<Meta http-equiv="Content-Type" content="text/html; charset=gb2312"> 通过session<a href="/tag/jinzhi/" target="_blank" class="keywords">禁止</a><a href="/tag/yemian/" target="_blank" class="keywords">页面</a>刷新 PHP //使用文本存储数据 if($_SESSION[temp]==""){ if(($fp=fopen("counter.txt","r"))==false){ echo "打开文件失败!"; }else{ $counter=fgets($fp,1024); //读取文件中数据 fclose($fp); //关闭文本文件 $counter++; //计数器增加1 $fp=fopen("counter.txt","w"); //以写的方式打开文本文件

fputs($fp,$counter); //将新的统计数据增加1
fclose($fp); } //关闭
//从文本文件中读取统计数据
if(($fp=fopen("counter.txt","r"))==false){
echo "打开文件失败!";
}else{
$counter=fgets($fp,1024);
fclose($fp);
echo "数字计数器: " .$counter ;
} //输出访问次数
$_SESSION[temp]=1; //登录以后,$_SESSION[temp]的值不为空,给$_SESSION[temp]赋一个值1
}else{
echo "";
}
?>
<table width="300" border="0" cellpadding="0" cellspacing="0" background="images/141.jpg">
<tr>
<td height="35" align="center"><span class="style1">通过session禁止页面刷新</td>
</tr>
<tr>
<td height="40" align="center"><span class="style2">
<?php if(($fp=fopen("counter.txt",1024);
fclose($fp);
echo "网页访问量: " .$counter ;
} //输出访问次数
?>
</td>
</tr>
<tr>
<td height="25" align="center"></td>
</tr>
</table>

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

希望本文所述对大家的PHP程序设计有所帮助。

猜你在找的PHP相关文章