Typecho
的垃圾评论还是比较多的,除了插件外,还可以通过PHP
函数实现简单的算术验证码。
第一步function.php
如下函数
function themeInit($comment){
$comment = spam_protection_pre($comment, $post, $result);
}
function spam_protection_math(){
$num1=rand(1,49);
$num2=rand(1,49);
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
添加函数
打开主题comments.php
文件,在适当为止插入如下代码:
<?php spam_protection_math();?>
如果觉得100以内太难了,请修复function.php
中添加的代码中rand
后面的数字范围。
文章转自:https://minirizhi.com/22.html
版权属于:泽泽社长
本文链接:https://blog.zezeshe.com/archives/typecho-suanshipinglun.html
本站未注明转载的文章均为原创,并采用
CC BY-NC-SA 4.0 授权协议,转载请注明来源,谢谢!
这个加了和没加也没有多大区别,填写一次可以重复提交,可以加个变量用于判断重复提交。
评论后页面会刷新数据也就会重新计算,ajax无刷新评论除外,不过感觉也无伤大雅,目的就是检测真人,检测好了第二次评论出现这种现象其实也无所谓
文章原作者有点皮
这份教程使我的站点成功的打不开了。。。
我把这个代码删了,好了。