CAPTCHAやスパムコメントチェッカーでスパムを単に撃退するのではなく、 DNSBLに対して各リクエストをチェックし、ユーザーが不正なIPを使用している場合はユーザーをブロックすることをお勧めしますか?
$blacklists = array('web.sorbs.net', 'opm.tornevall.org');
$parts = explode('.', $_SERVER['REMOTE_ADDR']);
$ip = implode('.', array_reverse($parts)) . '.';
foreach($blacklists as $bl)
{
$check = $ip . $bl;
if ($check != gethostbyname($check))
{
error_log('PHP Security: [DNSBL] - ' . $_SERVER['REMOTE_ADDR'] . ' - ' . $bl);
die('Put a detailed error here so the client knows why they have been blocked');
}
}
唯一の問題は、DNSBLによる優良ユーザーの過度のIPブロッキング、または要求ごとにDNSルックアップを行うための多額のコストであるように思われます。