IP ブラックリストの実装方法は、まずフィルタリングする IP を txt ファイルまたはデータベースに入れ、次に訪問時に IP アドレスを取得し、それを横断して比較します。
学校のニュース システムでは、一部のニュースは学校内の IP アドレスでのみ閲覧できるようにする必要があるため、この機能を実装するためにコードが書き直されました。実装後の結果は、アクセスが許可されている IP アドレスが IP アドレスにリストされている限り有効になります。 .txt ファイルでは、c クラス IP もサポートされます。例:
ip.txt
192.168
211.67.188
211.67.191.25
コードは次のとおりです:
コードは次のとおりです |
コードをコピー |
/*
* IPアドレスのブラックリスト、ホワイトリスト
* 訪問者のアドレスの IP が ip.txt にあり、クラス c ip をサポートしているかどうかを判断します
* xhat より
*/
$ip = $_SERVER['REMOTE_ADDR'];
$ipArray = preg_replace("#rn?|n#","",file('ip.txt'));
foreach ($ipArray として $ipTest) {
if (substr_count($ip, $ipTest) != "0") {
echo "ok" // 関連するコマンドを実行します
死ぬ();
}
}
?>
|
上記のコードを使用してチートすることができます。次のコードはアップグレードするためのものです
コードは次のとおりです |
コードをコピー |
クラス 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 as $k=>$v) {
if (!strstr($v,"-")) {
$preg_limit .= makePregIP($v);
}その他{
$aipNum = 爆発("-",$v);
for($i=$aipNum[0];$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[] = $ipaddres;
}
}
$ip_list を返す
}
パブリック関数 checkIP() {
$iptable = $this->getAllBlockIP();
$IsJoined = true
// ユーザー IP を取得します
$Ip = $this->get_client_ip();
$Ip = トリム($Ip)
//ブラックリストから IP セグメントを削除します
if ($iptable) {
foreach($iptable as $value) {
if (preg_match("{$value}",$Ip)) {
$IsJoined = false
休憩
}
}
}
// www.bKjia.c0m が IP ブラックリストに含まれている場合は、次の操作を実行します
if( !$IsJoined ){
「IP エラー」をエコーします
出る
}
}
プライベート関数 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']
それ以外は
$ip = "不明";
リターン($ip);
}
}
?>
引用:
コードは次のとおりです |
コードをコピー |
$oBlock_ip = 新しい block_ip();
$oBlock_ip->checkIP();
|
|
http://www.bkjia.com/PHPjc/632711.htmlwww.bkjia.comtruehttp://www.bkjia.com/PHPjc/632711.html技術記事 IP ブラックリストの実装方法は、まずフィルタリングする IP を txt ファイルまたはデータベースに入れ、次に訪問時に IP アドレスを取得し、それを横断して比較します。 学校...