首頁 > php教程 > php手册 > 主體

PHP限制IP访问 只允许指定IP访问 允许*号通配符过滤IP

WBOY
發布: 2016-06-13 10:54:08
原創
1083 人瀏覽過

[php]

01./**
02. * 检测访问的ip是否为规定的允许的ip
03. * Enter description here ...
04. */ 
05.function check_ip(){ 
06.    $ALLOWED_IP=array('192.168.2.*','127.0.0.1','192.168.2.49'); 
07.    $IP=getIP(); 
08.    $check_ip_arr= explode('.',$IP);//要检测的ip拆分成数组  
09.    #限制IP 
10.    if(!in_array($IP,$ALLOWED_IP)) { 
11.        foreach ($ALLOWED_IP as $val){ 
12.            if(strpos($val,'*')!==false){//发现有*号替代符  
13.                 $arr=array();//  
14.                 $arr=explode('.', $val); 
15.                 $bl=true;//用于记录循环检测中是否有匹配成功的  
16.                 for($i=0;$i 17.                    if($arr[$i]!='*'){//不等于*  就要进来检测,如果为*符号替代符就不检查  
18.                        if($arr[$i]!=$check_ip_arr[$i]){ 
19.                            $bl=false; 
20.                            break;//终止检查本个ip 继续检查下一个ip  
21.                        } 
22.                    } 
23.                 }//end for   
24.                 if($bl){//如果是true则找到有一个匹配成功的就返回  
25.                    return; 
26.                    die; 
27.                 } 
28.            } 
29.        }//end foreach  
30.        header('HTTP/1.1 403 Forbidden'); 
31.        echo "Access forbidden"; 
32.        die; 
33.    } 
34.} 
/**
 * 检测访问的ip是否为规定的允许的ip
 * Enter description here ...
 */
function check_ip(){
 $ALLOWED_IP=array('192.168.2.*','127.0.0.1','192.168.2.49');
 $IP=getIP();
 $check_ip_arr= explode('.',$IP);//要检测的ip拆分成数组
 #限制IP
 if(!in_array($IP,$ALLOWED_IP)) {
  foreach ($ALLOWED_IP as $val){
      if(strpos($val,'*')!==false){//发现有*号替代符
        $arr=array();//
        $arr=explode('.', $val);
        $bl=true;//用于记录循环检测中是否有匹配成功的
        for($i=0;$i          if($arr[$i]!='*'){//不等于*  就要进来检测,如果为*符号替代符就不检查
          if($arr[$i]!=$check_ip_arr[$i]){
           $bl=false;
           break;//终止检查本个ip 继续检查下一个ip
          }
         }
        }//end for
        if($bl){//如果是true则找到有一个匹配成功的就返回
         return;
         die;
        }
      }
  }//end foreach
  header('HTTP/1.1 403 Forbidden');
  echo "Access forbidden";
  die;
 }
}[php] 
01.  
 [php] 
01.

/**<br>
02. * 获得访问的IP<br>
03. * Enter description here ...<br>
04. */ <br>
05.function getIP() { <br>
06.    return isset($_SERVER["HTTP_X_FORWARDED_FOR"])?$_SERVER["HTTP_X_FORWARDED_FOR"] <br>
07.    :(isset($_SERVER["HTTP_CLIENT_IP"])?$_SERVER["HTTP_CLIENT_IP"] <br>
08.    :$_SERVER["REMOTE_ADDR"]); <br>
09.}
登入後複製

 
10.
登入後複製
 
11.
 
12.在需要检测的地方 加上调用 check_ip(); 即可;  本函数提供只允许指定的IP访问文件,并提供IP中*号通配符 匹配多IP www.2cto.com
 [php]
/**  * 获得访问的IP  * Enter description here ...  */  function getIP() {      return isset($_SERVER["HTTP_X_FORWARDED_FOR"])?$_SERVER["HTTP_X_FORWARDED_FOR"]      :(isset($_SERVER["HTTP_CLIENT_IP"])?$_SERVER["HTTP_CLIENT_IP"]      :$_SERVER["REMOTE_ADDR"]);  }  /**
 * 获得访问的IP
 * Enter description here ...
 */
function getIP() {
 return isset($_SERVER["HTTP_X_FORWARDED_FOR"])?$_SERVER["HTTP_X_FORWARDED_FOR"]
 :(isset($_SERVER["HTTP_CLIENT_IP"])?$_SERVER["HTTP_CLIENT_IP"]
 :$_SERVER["REMOTE_ADDR"]);
}


在需要检测的地方 加上调用 check_ip(); 即可;  本函数提供只允许指定的IP访问文件,并提供IP中*号通配符 匹配多IP

 

來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門推薦
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板