Ursprünglich wurden mehrere Funktionen geschrieben und die IP-Blacklist in der Bibliothek aufgezeichnet. Um das Verständnis zu erleichtern, wurde sie in eine Klasse zum Schreiben der IP-Blacklist geändert.
192.168.1.1 Einzel-IP
192.168.1.* Dieser Proxy 192.168.1.1-192.168.1-255
192.158.1.2-20 bedeutet 192.158.1.2-192.158.1.20
Sie können auch 192.168.1 schreiben.[1|2|3]
Hehe~ Ich weiß nicht, ob die Idee gründlich ist oder nicht, also werde ich sie zur Diskussion stellen und die folgenden Zitate verwenden:
$oBlock_ip = new block_ip();
$oBlock_ip->checkIP();
Das Folgende ist ein zitiertes Fragment:
<?php
Klasse block_ip {
var $Block_ip = array("192.168.1.1","210.10.2.1-20","222.34.4.*");
Funktion __construct(){
}
Funktion __destruct(){
}
private Funktion makePregIP($str){
if (strstr($str,"-")) {
$aIP = explosion(".",$str);
foreach ($aIP as $k=>$v) {
if (!strstr($v,"-")) {
$preg_limit .= makePregIP($v);
} anders{
$aipNum = explosion("-",$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."]";
}
}
}anders{
$preg_limit .= $str."";
}
return $preg_limit;
}
private Funktion 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;
}
öffentliche Funktion checkIP() {
$iptable = $this->getAllBlockIP();
$IsJoined = true;
//Benutzer-IP abrufen
$Ip = $this->get_client_ip();
$Ip = trim($Ip);
//IP-Segmente aus der Blacklist entfernen
if ($iptable) {
foreach($iptable as $value) {
if (preg_match("{$value}",$Ip)) {
$IsJoined = false;
brechen;
}
}
}
//Wenn es sich in der IP-Blacklist befindet, führen Sie die folgenden Vorgänge aus
if( !$IsJoined ){
echo „IP-Fehler“;
Ausfahrt;
}
}
private Funktion 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'];
anders
$ip = "unbekannt";
return($ip);
}
}
?>