首页 > CMS > Wordpress > 正文

wordpress禁止没有Gravatar头像的访客提交评论

2024-09-07 00:50:24
字体:
来源:转载
供稿:网友

为了防止垃圾评论各种方法都想尽了,下面我看网站有人说在wordpress禁止没有Gravatar头像的访客提交评论也可以防止机器提交了广告了,下面我们来看看.

1 为何限制没有Gravatar头像的访客

前几天博主就一直在想着是否要限制没有gravatar头像的用户在博客留言,主要原因有三点:

1、博客使用的是wordpress程序,而Gravatar早在07年就被Automattic公司收购并在wp程序上发扬光大,所以,wp博客和gravatar头像天生就是一对,当然要让他们在一起了.

2、屏蔽广告。很多spamer都是没有gravatar头像的,限制没有gravatar头像的访客就等于过滤掉了相当一部分的垃圾广告,扯远一点,多说插件为众多广告商做出了巨大贡献.

3、屏蔽毫无意义的评论。

一般没有gravatar头像的访客不会活跃在博客圈,大多是有问题就找你,一解决就拍屁股走人,博主深有体会,之前写了一篇《动易官方论坛的邀请码》,很多人拿到邀请码后连句谢谢都没有,博客本来就是一个交流的平台,失去了和用户的交互,那就没有任何意义了,所以,为了提升博客整体质量,需要屏蔽这部分访客.

那么接下来就说说实现“wordpress中限制没有Gravatar头像的访客提交评论”的具体方法:

2 判断是否具有Gravatar头像的函数

在functions.php中添加下面的函数,其作用是根据提交的email字段判断该留言者是否具有gravatar头像,还有种方法是通过http://www.gravatar.com/avatar/获取到头像文件的大小值是否为2637k来判断,具体方法大家可以参考《再议Gravatar头像缓存至本地服务器》中的代码,代码如下:

  1. /* 
  2.     * @author:vfhky 2013年09月11日20:23 
  3.     * @param string $email 用户提交的表单中的email字段 
  4.     * @return int 0:无gravatar头像; 1:有gravatar头像 
  5.     **/ 
  6.     function vfhky_checkgravatar($email){ 
  7.     $email_hash = md5(strtolower(trim($email))); 
  8.     $check_uri = 'http://www.gravatar.com/avatar/' . $email_hash . '?d=404'
  9.     $headers = @get_headers($check_uri); 
  10.     if (!preg_match("|200|"$headers[0])) { 
  11.     return 0; 
  12.     } 
  13.     else {return 1;} 
  14.     } 

3 在comments-ajax.php中调用判断函数

gravatar头像判断函数完成后,就可以在Willin Kan大神的comments-ajax.php文件中调用了,大概在该文件的90行处,在原代码中加入判断函数进行调用即可,代码如下:

  1. /* 
  2.     * @author:vfhky 2013年09月11日20:30 
  3.     * @param string $comment_author_email 用户提交的表单中的email字段 
  4.     **/ 
  5.     if ( !$user->ID ) { 
  6.     if ( 6 > strlen($comment_author_email) || '' == $comment_author ) 
  7.     err( __('提示:必须填写昵称及邮件。') ); 
  8.     elseif ( !is_email($comment_author_email)) 
  9.     err( __('提示:请输入一个有效的电子邮件地址。') ); 
  10.     elseif (vfhky_checkgravatar($comment_author_email) == 0) 
  11.     err( __('请使用Gravatar头像留言。') ); 
  12.     } 

4 后记:wordpress中限制没有Gravatar头像的访客提交评论,简单两步就实现了限制没有Gravatar头像的访客提交评论,当然,这个功能也可以用jquery实现,不过,一旦用户浏览器屏蔽了js,那么也就没效果了,所以,综合考虑还是用服务器端判断更为安全可靠,虽然增加了额外资源的消耗.

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表