ほとんど放置気味の Wiki に、適当なアカウントが登録されては長文(ドイツ語)のページが作られる、というのがここ数日続いていました。見にくる人はほとんどいないし、その作られたページはさらにどこからもリンクされていないし、まったく誰にも何の得もない所業だと思うのですが、放っておくわけにもいかず、ちまちまと削除していました。
この Wiki は MediaWiki で運用しています。最近の MediaWiki には最初から ConfirmEdit という拡張機能が同梱されています。この機能の SimpleCaptcha というものを以前から有効化していました。これは、アカウント作成時や新規ページ作成時に、簡単な数式(足し算や引き算)の答を入力させるというものでした。にも関わらず変なアカウントやページを作られていたわけですから、スパムボット(いやまさか人力ではあるまい)はこれに対応したものだったようです。
数日続いたのでだんだん嫌になり、同じ ConfirmEdit の QuestyCaptcha を使うように、設定を変更しました。
LocalSettings.php の記述は
require_once ( "$IP/extensions/ConfirmEdit/ConfirmEdit.php" ); require_once ( "$IP/extensions/ConfirmEdit/QuestyCaptcha.php" ); $wgCaptchaClass = 'QuestyCaptcha' ; $wordarr = array ( "日本語で質問に答えてください。質問1" => "答え1" , "日本語で質問に答えてください。質問2" => "答え2" , "日本語で質問に答えてください。質問3" => "答え3" , "日本語で質問に答えてください。質問4" => "答え4" , "日本語で質問に答えてください。質問5" => "答え5" , ); foreach ( $wordarr as $key => $value ) { $wgCaptchaQuestions [] = array ( 'question' => $key , 'answer' => $value ); } $wgCaptchaTriggers [ 'edit' ] = true; $wgCaptchaTriggers [ 'create' ] = true; $wgCaptchaTriggers [ 'addurl' ] = true; $wgCaptchaTriggers [ 'createaccount' ] = true; $wgCaptchaTriggers [ 'badlogin' ] = true; |
のようにします。質問はランダムに表示されます。質問と答を日本語とすることにより、日本語話者かどうかの判定も兼ねるようにしました。
しかしこの設定は、管理者の負担を善意のユーザーに転嫁するものでもあります。そのようなユーザーには CAPTCHA を求めないように、
$wgCaptchaWhitelistIP = array ( '192.168.0.0/24' ); // 安全な接続元を IP アドレスで指定 $ceAllowConfirmedEmail = true; // メールアドレスを確認済みのユーザーは安全とみなす |
も設定しておくことにします。
これでしばらく様子を見ることにします。