WordPress评论添加验证码

虽然WordPress自带插件Akismet已经非常强大,足以挡住大多数垃圾评论,但Akismet只是将这些垃圾评论放到了“垃圾”里,仍然需要我们手动去清理,如果连垃圾评论都不想看到,还是给WordPress评论加个验证机制吧!

首先为表单增加验证字段,在主题文件functions.php中添加如下代码:

1
2
3
4
5
6
7
8
9
10
function verification_fields($fields) {
    $num_o = rand(0, 99);
    $num_t = rand(0, 99);
    $fields['verification'] = '<input name="num_o" value="' . $num_o . '" type="hidden" />' .
                    '<input name="num_t" value="' . $num_t . '" type="hidden" />' .
                    '<p class="verification-code"><label for="verification-code">验证:</label>' .
                    $num_o . ' + ' . $num_t . ' = ' . '<input id="verification-code" name="pcodes" type="text" value="" size="4" /></p>';
    return $fields;
}
add_filter('comment_form_default_fields', 'verification_fields');

这里给评论表单添加了一个算术运算的验证,然后添加提交评论时验证计算结果的代码,仍然是放在主题文件functions.php中:

1
2
3
4
5
6
7
8
9
10
11
function verification_code() {
    if ( ! $user->ID ) {
        $num_o = trim($_POST['num_o']);
        $num_t = trim($_POST['num_t']);
        $pcodes = trim($_POST['pcodes']);
        if( $pcodes != $num_o + $num_t ) {
            wp_die( __('错误提示:请输入正确的验证码。') );
        }
    }
}
add_filter('pre_comment_on_post', 'verification_code');

在实际应用中,这种简单的算术计算可能还是会被灌水,可以考虑将$num_o + $num_t生成为图片,并用条纹干扰再输出,另外隐藏字段中$num_o和$num_t的值可以加密一下,验证那里再解密。

原文链接:https://xiaohost.com/2358.html,转载请注明出处。
0