网站添加提交评论验证码
in Skill with Views 440

网站添加提交评论验证码

in Skill with Views 441

本来是打算给网站加上一个滑动验证提交的,虽然找到了一个插件,但苦于年久失修,并且需要加载JQ。本着能用JS的情况下绝不用JQ的初衷,于是乎只能放弃。

szyz.jpg

偶然在黑冰技术站上发现了一段简单的数字验证代码。

经博主测试可用,百度里关于Typecho技术的教程真心不多。博主又是小白一个,em,跑题了。

直接放代码,将以下代码放入主题的function.php文件中。

//算术验证评论
function themeInit($comment){
$comment = spam_protection_pre($comment);
}
function spam_protection_math(){
    $num1=rand(1,100);
    $num2=rand(1,100);
    echo "<label for=\"math\">请输入<code>$num1</code>+<code>$num2</code>的计算结果:</label>\n";
    echo "<input type=\"text\" name=\"sum\" class=\"text\" value=\"\" size=\"25\" tabindex=\"4\" style=\"width:218px\" placeholder=\"计算结果:\">\n";
    echo "<input type=\"hidden\" name=\"num1\" value=\"$num1\">\n";
    echo "<input type=\"hidden\" name=\"num2\" value=\"$num2\">";
}
function spam_protection_pre($comment, $post, $result){
    $sum=$_POST['sum'];
    switch($sum){
        case $_POST['num1']+$_POST['num2']:
        break;
        case null:
        throw new Typecho_Widget_Exception(_t('对不起: 请输入验证码。<a href="javascript:history.back(-1)">返回上一页</a>','评论失败'));
        break;
        default:
        throw new Typecho_Widget_Exception(_t('对不起: 验证码错误,请<a href="javascript:history.back(-1)">返回</a>重试。','评论失败'));
    }
    return $comment;
}

接着打开评论模板comments.php文件,在模板中找到提交按钮的代码,在其上方插入下方代码即可。

<?php spam_protection_math();?>

关于CSS样式部分,可直接在function.php文件中的算术验证代码里修改。

如果觉得100以内太难了,请修改function.php中添加的代码中rand后面的数字范围。

Responses