下面我提供一段php的代码,可以起到一定的防cc攻击效果。
主要功能:在3秒内连续刷新页面5次以上将指向本机 http://127.0.0.1
只需将该代码放到需要防cc攻击的页面即可。
源码
下面是为大家整理的php防cc攻击的有效方法:
1.session记录
submit.php为发送页面,在这个页面上设置一个session变量,并作为隐藏域和表单一起发送到submitdeal.php页面,在服务器端把post上来的隐藏变量和服务器端记录的session变量进行对比,比如一样,则写入数据库并清除session,这样用户刷新页面,两个值不相等提示错误或跳转。
优点:不用用户输入验证码
缺点:表单容易被复制
2.验证码
原理和第一种一样,只是session数据不作为隐藏域提交,而是让用户填写,大多数网站都采用文字验证码和图片验证码,图片验证码安全性高。
3.ip绑定
提交数据后,先从ip表里检索客户端ip,如果有,并且没有过期,那么报错,否则写入数据库,然后再取客房端ip,把ip写入数据库。
4.cookie:客户提交后处理程序先检索客户端有没有设置cookie,如果有,则不重复提交;如果没有,则写数据,再写个cookie;
例:
用户无意义的频繁跳转、请求都会给服务器加重很多负担 其实 用cookie就可以防止这一点。
方式一:
$allowtime){ $refresh = true; $_session[$allowt] = time(); }else{ $refresh = false; } ?>
方式二:
方式三:
以上就是php防止cc攻击的多种方式,希望能帮助大家防止网页快速恶意刷新。
