ホームページ >バックエンド開発 >PHPチュートリアル >PHP が IP ブラックリストのプログラム コードを決定する_PHP チュートリアル

PHP が IP ブラックリストのプログラム コードを決定する_PHP チュートリアル

WBOY
WBOYオリジナル
2016-07-13 10:49:38824ブラウズ

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.comtru​​ehttp://www.bkjia.com/PHPjc/632711.html技術記事 IP ブラックリストの実装方法は、まずフィルタリングする IP を txt ファイルまたはデータベースに入れ、次に訪問時に IP アドレスを取得し、それを横断して比較します。 学校...
声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。