php防止恶意频繁刷新页面或form提交

简介:

php防止恶意频繁刷新页面或form提交


很多方法:(以下仅简单方法的简单思路,对于防止菜鸟“黑客”足矣):

1、检测referer来源地址是否为本站。($_SERVER['HTTP_REFERER'])

2、使用验证码来验证数据提交的合法性,能使用验证码就尽量使用。

3、记录IP,一定时间内禁止此ip进行二次提交/刷新。

4、前台用js生成随机加密码。

等等......



自己根据网上的实例瞎弄了一个(仅供参考):

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
<?php
session_start();
function  getIps(){
     if ( getenv ( 'HTTP_CLIENT_IP' ) &&  strcasecmp ( getenv ( 'HTTP_CLIENT_IP' ),  'unknown' )){
     $IP  getenv ( 'HTTP_CLIENT_IP' );
     elseif ( getenv ( 'HTTP_X_FORWARDED_FOR' ) &&  strcasecmp ( getenv ( 'HTTP_X_FORWARDED_FOR' ),  'unknown' )) {
     $IP  getenv ( 'HTTP_X_FORWARDED_FOR' );
     elseif ( getenv ( 'REMOTE_ADDR' ) &&  strcasecmp ( getenv ( 'REMOTE_ADDR' ),  'unknown' )) {
     $IP  getenv ( 'REMOTE_ADDR' );
     elseif (isset( $_SERVER [ 'REMOTE_ADDR' ]) &&  $_SERVER [ 'REMOTE_ADDR' ] &&  strcasecmp ( $_SERVER [ 'REMOTE_ADDR' ],  'unknown' )) {
     $IP  $_SERVER [ 'REMOTE_ADDR' ];
     }
     return  $IP  $IP  "unknow" ;
}
function  allowRefresh( $parameter ){
     date_default_timezone_set( 'Asia/Shanghai' );
     $nowUserIp  = getIps();
     $allowOldTime  = md5( $parameter . $nowUserIp );
                   
     $allowTime  = 3; //防刷新时间。单位:秒 10秒之后才能再次提交(刷新)
                   
     if (!isset( $_SESSION [ $allowOldTime ])){
         $_SESSION [ $allowOldTime ] = time();
         return  true;
     }
     elseif (time() -  $_SESSION [ $allowOldTime ] >  $allowTime ){
         $_SESSION [ $allowOldTime ] = time();
         return  true;
     }
     else {
         return  false;
     }
}
                   
if ( $_GET ){
     $k = $_GET [ 'k' ];
     $submitKey = $_GET [ 'submitKey' ];
     $toCheckStr = $k . $submitKey ;
     if ( empty ( $k )|| empty ( $submitKey )||( $submitKey  !==  'true' )){
         die ( 'errormsg' );
     }
                   
     if (allowRefresh( $toCheckStr )==true){
         echo  'Congratulations!<br />mysql听令:去搜索俺想要的结果!继续往下执行...' ;
     }
     else {
         echo  '请不要频繁提交' ;
     }
}
?>
<meta http-equiv= "Content-Type"  content= "text/html; charset=UTF-8"  />
<form action= ""  method= "get" >
     <input type= "text"  name= "k"  /><br />
     <input type= "text"  name= "submitKey"  value= "true"  />
     <input type= "submit"  value= "提交"  />
</form>








      本文转自许琴 51CTO博客,原文链接:http://blog.51cto.com/xuqin/1265776,如需转载请自行联系原作者




相关文章
|
8月前
|
PHP
php 正则匹配 常用的 规则(一) 匹配form表单
php 正则匹配 常用的 规则(一) 匹配form表单
38 0
|
8月前
|
PHP
php 正则匹配 规则(二)匹配form表单 示例
php 正则匹配 规则(二)匹配form表单 示例
42 0
|
SQL JavaScript 安全
php操作mysql防止sql注入(合集)
php操作mysql防止sql注入(合集)
403 0
|
API PHP
PHP对接百度API访问自动提交收录SEO
PHP对接百度API访问自动提交收录
601 0
PHP对接百度API访问自动提交收录SEO
PHP获取当前页面的FORM表单提交
PHP获取当前页面的FORM表单提交
269 0
PHP获取当前页面的FORM表单提交
|
JSON 前端开发 JavaScript
如何把文件提交给接口上传到服务器(php版)
如何把文件提交给接口上传到服务器(php版)
333 0
|
Web App开发 数据采集 PHP
php 防止爬虫设置
php代码如图所示:
880 0
|
Web App开发 SQL PHP
PHP获取IP地址的方法,防止伪造IP地址注入攻击
原文:PHP获取IP地址的方法,防止伪造IP地址注入攻击 PHP获取IP地址的方法 /** * 获取客户端IP地址 * 来源:ThinkPHP * "X-FORWARDED-FOR" 是代理服务器通过 HTTP Headers 提供的客户端IP。
2099 0