在設定區域網路共享檔案存取權限的過程中,有時候我們會處於共享檔案管理安全管理的需要,而禁止某個IP位址存取區域網路共享檔案、禁止某台電腦存取伺服器共享文件。這一方面可以透過設定共享資料夾的使用者存取權限來實現,例如我們可以禁止某個使用者存取共用資料夾,但是有可能別人會將有權限存取共用檔案的使用者透漏給存取者,使得訪客利用其它帳號同樣可以存取共享文件。那麼,在這種情況下,我們可以透過以下方法來阻止指定電腦存取共用資料夾。
這篇文章主要介紹了PHP實作限制IP存取的方法,涉及php針對客戶端IP的取得、解析、遍歷、判斷等相關操作技巧,需要的朋友可以參考下
本文實例敘述了PHP實作限制IP存取的方法。分享給大家供大家參考,具體如下:
//获取客户端ip if (getenv("HTTP_CLIENT_IP")) $ip = getenv("HTTP_CLIENT_IP"); else if(getenv("HTTP_X_FORWARDED_FOR")) $ip = getenv("HTTP_X_FORWARDED_FOR"); else if(getenv("REMOTE_ADDR")) $ip = getenv("REMOTE_ADDR"); else $ip = "Unknow"; $ALLOWED_IP=array('10.144.39.132'); //允许访问的ip $check_ip_arr= explode('.',$ip); //ip参数拆分成数组 if(!in_array($ip,$ALLOWED_IP)) { $bl=false; foreach ($ALLOWED_IP as $val){ if(strpos($val,'*')!==false){ //发现有*号替代符 $arr=array(); $arr=explode('.', $val); $bl=true; //用于记录循环检测中是否有匹配成功的 for ($i=0;$i<4;$i++){ if($arr[$i]!='*'){ //不等于* 就要进来检测,如果为*符号替代符就不检查 if($arr[$i]!=$check_ip_arr[$i]){ $bl=false; break; //终止检查本个ip 继续检查下一个ip } } } //end for if($bl){ //如果是true则终止匹配 break; } } } //end foreach if(!$bl){ $return=array( 'status'=>2, 'msg'=>'该IP无权限访问', 'data'=>$ip ); echo json_encode($return); exit(); } }
以上是php 限制某個IP存取的實作方法的詳細內容。更多資訊請關注PHP中文網其他相關文章!