원래는 여러 기능이 작성되어 있었는데, IP 블랙리스트를 라이브러리에 기록해 두었는데, 이해를 돕기 위해 IP 블랙리스트를 작성하는 클래스로 변경했습니다.
192.168.1.1 단일 IP
192.168.1.* 이 프록시 192.168.1.1-192.168.1-255
192.158.1.2-20은 192.158.1.2-192.158.1.20을 의미합니다.
192.168.1.[1|2|3]이라고 쓸 수도 있습니다.
헤헤~ 아이디어가 철저한지 아닌지 잘 모르겠어서 논의에 들고 다음 인용문을 사용하겠습니다.
$oBlock_ip = 새로운 block_ip();
$oBlock_ip->checkIP();
다음은 인용된 부분입니다:
<?php
클래스 block_ip {
var $Block_ip = array("192.168.1.1","210.10.2.1-20","222.34.4.*");
함수 __construct(){
}
함수 __destruct(){
}
개인 함수 makePregIP($str){
if (strstr($str,"-")) {
$aIP = 폭발(".",$str);
foreach ($aIP는 $k=>$v) {
if (!strstr($v,"-")) {
$preg_limit .= makePregIP($v);
} 또 다른{
$aipNum = 폭발("-",$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."]";
}
}
}또 다른{
$preg_limit .= $str.".";
}
$preg_limit를 반환합니다.
}
개인 함수 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[] = $ip주소;
}
}
$ip_list를 반환합니다.
}
공개 함수 checkIP() {
$iptable = $this->getAllBlockIP();
$IsJoined = 사실;
//사용자 IP 가져오기
$Ip = $this->get_client_ip();
$Ip = 트림($Ip);
//블랙리스트에서 IP 세그먼트를 제거합니다.
if ($iptable) {
foreach($iptable을 $value로) {
if (preg_match("{$value}",$Ip)) {
$IsJoined = 거짓;
부서지다;
}
}
}
//IP 블랙리스트에 있는 경우 다음 작업을 수행합니다.
if( !$IsJoined ){
echo "IP 오류";
출구;
}
}
개인 함수 get_client_ip(){
if (getenv("HTTP_CLIENT_IP") && strcasecmp(getenv("HTTP_CLIENT_IP"), "알 수 없음"))
$ip = getenv("HTTP_CLIENT_IP");
else if (getenv("HTTP_X_FORWARDED_FOR") && strcasecmp(getenv("HTTP_X_FORWARDED_FOR"), "알 수 없음"))
$ip = getenv("HTTP_X_FORWARDED_FOR");
else if (getenv("REMOTE_ADDR") && strcasecmp(getenv("REMOTE_ADDR"), "알 수 없음"))
$ip = getenv("REMOTE_ADDR");
else if (isset($_SERVER['REMOTE_ADDR']) && $_SERVER['REMOTE_ADDR'] && strcasecmp($_SERVER['REMOTE_ADDR'], "알 수 없음"))
$ip = $_SERVER['REMOTE_ADDR'];
또 다른
$ip = "알 수 없음";
반환($ip);
}
}
?>