-1

我正在尝试编写一个简单的 PHP 通用块包含代码,它将读取文本文件以填充 IP 数组,然后使用该数组比较访问者 IP 以确定它是否应该结束页面显示,阻止该页面或网站。此代码还将日志行放入 403 文件,然后发送失败者(用户)查看它,结束他们对该站点的访问。该行将其信息附加到开放式 403 文件的末尾。

包含可以放在您不希望该 IP 列表看到的任何地方。问题是我是一个无可救药的黑客,并且没有很好地掌握这些循环和语法。你能帮我解决这个问题吗?似乎可以读取 IP 列表,但是 while 循环似乎是错误的。我可以进一步简化这一点。但我不确定问题是什么......我选择的变量名......也许。

<? 
$IP = $_SERVER['REMOTE_ADDR'];


        $link_file = "bannedips.dat";
        $lines = file($link_file);

        foreach($lines as $line){
            if(!empty($line)){
                $line_array = explode(',', $line);
                $bannedip = trim(trim(strip_tags($line_array[0]), "\x00..\x1F"));
            }
        }



while $bannedip if ((substr($IP,0,10) == $bannedip) {
$line = date('Y-m-d H:i:s') . " - <b>$IP</b><br>\n";

file_put_contents('403.shtml', $line . PHP_EOL, FILE_APPEND);
header('Location: 403.shtml');
die();
}
?>
4

2 回答 2

0

您可以从文件中构建一个被禁止 IP 的数组(您只是覆盖代码中的最后一个,用于$bannedip[]将其添加到列表中),然后用于in_array()根据该列表检查用户 IP...

$link_file = "bannedips.dat";
$lines = file($link_file);
$bannedip = [];   // Create start array
foreach($lines as $line){
    if(!empty($line)){
        $line_array = explode(',', $line);
        $bannedip[] = trim(trim(strip_tags($line_array[0]), "\x00..\x1F"));
    }
}
if(in_array($IP, $bannedip )) {
    $line = date('Y-m-d H:i:s') . " - <b>$IP</b><br>\n";
    file_put_contents('403.shtml', $line . PHP_EOL, FILE_APPEND);
    header('Location: 403.shtml');
    die();
}

处理输入文件可能有一种更整洁的方式,但在不知道格式的情况下很难说,所以我保留了您的代码。

更新:

如果您禁止的 IP 文件只是 IP 地址列表,您可以将负载替换为foreach...

$bannedip = file($link_file, FILE_IGNORE_NEW_LINES);
$bannedip = array_filter($bannedip);

更新2: 您似乎已经自己解决了这个问题,但是发布了您拥有的实际文件格式的示例,我想我会添加它是如何完成的......

$IP= "31.130.4.241";
$link_file = "bannedips.dat";
$bannedip = file($link_file, FILE_IGNORE_NEW_LINES);
$bannedip = array_map("str_getcsv", $bannedip);
$bannedip = array_column($bannedip, null, 0);
if(isset($bannedip[$IP])) {
    $line = date('Y-m-d H:i:s') . " - <b>{$bannedip[$IP][0]}</b> - {$bannedip[$IP][1]} - {$bannedip[$IP][2]}<br>\n";
    file_put_contents('403.shtml', $line . PHP_EOL, FILE_APPEND);
    header('Location: 403.shtml');
    die();
}
于 2018-06-07T10:39:19.520 回答
0

最初的目标是编写一小段 INCLUDE 代码,用于解析文本文件、找到匹配的 IP、记录信息并将垃圾邮件混蛋丢到 403 页面。这样,违规用户可以访问任何页面,除了包含这段脚本的页面。非常有选择性的阻断。

这是我的最终代码:

  <? 
    $IP = $_SERVER['REMOTE_ADDR'];
    echo $IP;
    $link_file = "bannedips.dat";
    $lines = file($link_file);

            foreach($lines as $line){
                if(!empty($line)){
                    $line_array = explode(',', $line);
                    $inputip = trim(trim(strip_tags($line_array[0]), "\x00..\x1F"));
                    $website = trim(trim(strip_tags($line_array[1]), "\x00..\x1F"));
                    $email = trim(trim(strip_tags($line_array[2]), "\x00..\x1F"));

                    if($IP == $inputip) {
                        $line = date('Y-m-d H:i:s') . " - <b>$inputip</b> - $website - $email<br>\n";
                        file_put_contents('403.shtml', $line . PHP_EOL, FILE_APPEND);
                        header('Location: 403.shtml');
                        die();
                    }
                }
            }
    ?>

数据文件格式如下:

23.105.159.238,penilengorgement.com,randomjerk@spammer.net
31.130.4.240,scamtown.com,spameister@viagraads.com

因此,现在当我禁止 IP(垃圾邮件发送者)时,它会从我的博客中提取他们的信息,并将其放入链接文件中,在那里可以对其进行解析并用于记录屡犯者,并为他们提供尝试进入我网站的替代方法,通过向他们提供同行名单。

于 2018-06-10T13:22:06.760 回答