이 글에서는 IP 블랙리스트 프로그램을 판단하는 PHP의 코드 예시를 주로 소개합니다. 필요한 친구들은 참고하면 됩니다.
학교 뉴스 시스템에서는 일부 뉴스는 학교 IP로만 열람할 수 있도록 요구하므로 구현하기 위해 코드를 다시 작성했습니다. 이 기능을 구현한 후에는 ip.txt 파일에 액세스가 허용된 IP만 나열하면 됩니다. 예:
ip.txt
192.168
211.67. 188
211.67.191.25
코드는 다음과 같습니다.
코드는 다음과 같습니다.
/* * ip地址黑名单、白名单 * 判断访客地址的ip是否在ip.txt中,支持c类ip * By xhat */ $ip = $_SERVER['REMOTE_ADDR']; $ipArray = preg_replace("#rn?|n#","",file('ip.txt')); foreach ($ipArray as $ipTest) { if (substr_count($ip, $ipTest) != "0") { echo "ok"; //执行相关命令 die(); } } ?>
위 코드를 사용하여 치트를 사용할 수 있으며, 아래 코드는 업그레이드되었습니다.
코드는 다음과 같습니다
<?php class block_ip { var $Block_ip = array("192.168.1.1","210.10.2.1-20","222.34.4.*"); function construct(){ } function destruct(){ } private function makePregIP($str){ if (strstr($str,"-")) { $aIP = explode(".",$str); foreach ($aIP as $k=>$v) { if (!strstr($v,"-")) { $preg_limit .= makePregIP($v); } else{ $aipNum = explode("-",$v); for($i=$aipNum[0];$i<=$aipNum[1];$i++){ $preg .=$preg?"|".$i:"[".$i; } $preg_limit .=strrpos($preg_limit,".",1)==(strlen($preg_limit)-1)?$preg."]":".".$preg."]"; } } }else{ $preg_limit .= $str."."; } return $preg_limit; } private function getAllBlockIP(){ if ($this->Block_ip) { foreach ($this->Block_ip as $k=>$v) { $ipaddres = $this->makePregIP($v->start_ip); $ip = str_ireplace(".",".",$ipaddres); $ip = str_replace("*","[0-9]{1,3}",$ip); $ipaddres = "/".$ip."/"; $ip_list[] = $ipaddres; } } return $ip_list; } public function checkIP() { $iptable = $this->getAllBlockIP(); $IsJoined = true; //取得用户ip $Ip = $this->get_client_ip(); $Ip = trim($Ip); //剔除黑名单中的IP区段 if ($iptable) { foreach($iptable as $value) { if (preg_match("{$value}",$Ip)) { $IsJoined = false; break; } } } // 如果在ip黑名单中就执行如下操作 if( !$IsJoined ){ echo "IP Error"; exit; } } private function get_client_ip(){ if (getenv("HTTP_CLIENT_IP") && strcasecmp(getenv("HTTP_CLIENT_IP"), "unknown")) $ip = getenv("HTTP_CLIENT_IP"); else if (getenv("HTTP_X_FORWARDED_FOR") && strcasecmp(getenv("HTTP_X_FORWARDED_FOR"), "unknown")) $ip = getenv("HTTP_X_FORWARDED_FOR"); else if (getenv("REMOTE_ADDR") && strcasecmp(getenv("REMOTE_ADDR"), "unknown")) $ip = getenv("REMOTE_ADDR"); else if (isset($_SERVER['REMOTE_ADDR']) && $_SERVER['REMOTE_ADDR'] && strcasecmp($_SERVER['REMOTE_ADDR'], "unknown")) $ip = $_SERVER['REMOTE_ADDR']; else $ip = "unknown"; return($ip); } } ?>
견적 조각:
코드는 다음과 같습니다:
$oBlock_ip = new block_ip(); $oBlock_ip->checkIP();
위 내용은 PHP 판단 IP 블랙리스트 프로그램 코드 예제에 대한 자세한 설명의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!