PHP implementiert Code-Sharing, um den IP-Zugriff und die Übermittlungszeiten zu begrenzen

小云云
Freigeben: 2023-03-19 22:18:02
Original
1730 Leute haben es durchsucht

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
Nach dem Login kopieren

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
Nach dem Login kopieren

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!=&#39;unknow&#39;)
      $ip=$ip1; else if($ip2&&$ip2!=&#39;unknow&#39;)
      $ip=$ip2; else if($ip3&&$ip3!=&#39;unknow&#39;)
      $ip=$ip3; else
      $ip=&#39;127.0.0.1&#39;;
  }
}
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=&#39;Error.php&#39;;</script>";
}
Nach dem Login kopieren

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[&#39;login_error&#39;])){
    if($_SESSION[&#39;login_error&#39;] == 3){
      exit("这里已经是第三次了");
    } else{
      $_SESSION[&#39;login_error&#39;] = $_SESSION[&#39;login_error&#39;]++;
    }
  } else{
    $_SESSION[&#39;login_error&#39;] = 1;
  }
}
Nach dem Login kopieren

Verwandte Empfehlungen:

PHP schränkt den IP-Zugriff ein, erlaubt nur den angegebenen IP-Zugriff, erlaubt * Platzhalter zum Filtern von IP_PHP-Tutorial

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!

Verwandte Etiketten:
Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage
Über uns Haftungsausschluss Sitemap
Chinesische PHP-Website:Online-PHP-Schulung für das Gemeinwohl,Helfen Sie PHP-Lernenden, sich schnell weiterzuentwickeln!