Heim >Backend-Entwicklung >PHP-Tutorial >PHP implementiert Code-Sharing, um den IP-Zugriff und die Übermittlungszeiten zu begrenzen
Dieser Artikel stellt Ihnen hauptsächlich die Methode zur Begrenzung des IP-Zugriffs und der Übermittlungszeiten in PHP vor. Dazu gehört die Erfassung und Beurteilung der besuchenden IP des Clients durch PHP sowie damit verbundene Betriebsfähigkeiten wie das Aufzeichnen der Anzahl der IP-Zugriffe in Kombination mit dem Ich hoffe, dass Freunde in Not darauf verweisen können.
1. Prinzip
Zum Beispiel, wenn sich ein Benutzer anmeldet macht einen Fehler. Vergessen Sie, dass die Anzahl der Datenbankschreibfehler 1 und der Zeitpunkt des Fehlers beträgt. Wenn der Fehler erneut auftritt, schreiben Sie 2. Wenn er 5 Mal erreicht ist, werden Sie aufgefordert, sich nicht erneut anzumelden. Bitte versuchen Sie es morgen erneut und berechnen Sie dann mit DateDiff die Zeit zwischen dem Fehler und now(). Wenn sie größer als 24 ist, öffnen Sie es einfach und lassen Sie ihn es versuchen.
Es ist relativ einfach, die IP zu blockieren, insbesondere die IP zu trennen.
Lassen Sie uns zunächst über die Situation beim Öffnen des IP-Segments sprechen: Nehmen Sie zuerst die IP heraus, auf die der Kunde zugreift Der Einfachheit halber ist IP192.168.6 eingestellt.2
Jetzt möchten wir das IP-Segment von 192.168.*.* öffnen. Bitte geben Sie uns einen Code, der leichter zu verstehen ist:
url=split(ip,".") '这里的ip为客户端IP fsip="192.168.*.*" '允许的段,可以从数据库取出,也可以这么定义 fip=split(fsip,".") if fip(0)=url(0) and fip(1)=url(1) then response.write "您的IP被封" else response.write "可以通过" end if
Tatsächlich ist das Sperren einer IP dieselbe wie die oben beschriebene Methode. Oder entnehmen Sie einfach den direkten Vergleich zwischen IP und Client aus der Datenbank.
Im Allgemeinen ist das IP-Segment in der Datenbank auf doppelte Genauigkeit eingestellt, dann werden diese benötigt:
if Request.ServerVariables("HTTP_X_FORWARDED_FOR")="" then IP=Request.ServerVariables("REMOTE_ADDR") else IP=Request.ServerVariables("HTTP_X_FORWARDED_FOR") end if sip=IP cip=split(ip,".") ip=256*256*256*cip(0)+256*256*cip(1)+256*cip(2)+cip(3)-1
Die oben genannten Situationen sind alle in In Bedingungen für Datenbankoperationen, Cookies usw. sind nicht betroffen.
Tatsächlich ist das Blockieren von IP nicht sehr ideal und wirkt sich auf unschuldige Personen aus. Der relevante Grund könnte sein, dass dynamische IP-Adressen entkommen.
2. Kapselungsbeispiel
<?php class IP{ //获取客户IP地址 function getIpAdr(&$ip){ $ip1=getenv("HTTP_X_FORWARDED_FOR"); $ip2=getenv("HTTP_CLIENT_IP"); $ip3=getenv("REMOTE_ADDR"); if($ip1&&$ip1!='unknow') $ip=$ip1; else if($ip2&&$ip2!='unknow') $ip=$ip2; else if($ip3&&$ip3!='unknow') $ip=$ip3; else $ip='127.0.0.1'; } } function get_netip($myip){ //只留客户IP地址的前三位 $temp=explode(".",$myip); $netip.=$temp[0]; $netip.="."; $netip.=$temp[1]; $netip.="."; $netip.=$temp[2]; return $netip; } $filename="test.ini"; //定义操作文件 $ip_lib=file($filename); //读取文件数据到数组中 $allow=0; $IP=new IP; $thisip=""; $IP->getIpAdr(&$thisip); $thenetip=get_netip($thisip); for ($i=0;$i<count($ip_lib);$i++){ if(ereg($thenetip,$ip_lib[$i])){ $allow=1; break; } } if ($allow==1) { echo "验证通过"; } else { echo "<script>location.href='Error.php';</script>"; }
3
1. Die Seite benötigt zuerst session_start() 2. Treffen Sie eine Beurteilung, wenn Sie zum Anmelden klicken. Wenn festgestellt wird, dass das vom Benutzer eingegebene Passwort falsch ist
if(用户的密码是错误的){ if(!empty($_SESSION['login_error'])){ if($_SESSION['login_error'] == 3){ exit("这里已经是第三次了"); } else{ $_SESSION['login_error'] = $_SESSION['login_error']++; } } else{ $_SESSION['login_error'] = 1; } }
Verwandte Empfehlungen:
Das obige ist der detaillierte Inhalt vonPHP implementiert Code-Sharing, um den IP-Zugriff und die Übermittlungszeiten zu begrenzen. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!