之前有网友提出,在WordPress中有没有方法完成每篇文章只容许用户评论一次?
暂不说这个需要有没有用,毕竟WordPress就是给有各种需要的人用的。这个性能完成起来也比拟简略,只要每次用户宣布的评论进数据库之前,从以后文章的一切评论中查找能否有相反的用户名或邮箱曾经宣布过评论,假如有就跳到谬误页面即可。
完成代码,放到以后主题的functions.php中即可(这里还添加了对IP的判别,更保险):
// 获取评论用户的ip,参考wp-includes/comment.php function ludou_getIP() { $ip = $_SERVER['REMOTE_ADDR']; $ip = preg_replace( '/[^0-9a-fA-F:., ]/', '', $ip ); return $ip; } function ludou_only_one_comment( $commentdata ) { global $wpdb; $currentUser = wp_get_current_user(); // 不限度治理员宣布评论 if(empty($currentUser->roles) || !in_array('administrator', $currentUser->roles)) { $bool = $wpdb->get_var("SELECT comment_ID FROM $wpdb->comments WHERE comment_post_ID = ".$commentdata['comment_post_ID']." AND (comment_author = '".$commentdata['comment_author']."' OR comment_author_email = '".$commentdata['comment_author_email']."' OR comment_author_IP = '".ludou_getIP()."') LIMIT 0, 1;"); if($bool) wp_die('本站每篇文章只容许评论一次。<a href="'.get_permalink($commentdata['comment_post_ID']).'">点此前往</a>'); } return $commentdata; } add_action( 'preprocess_comment' , 'ludou_only_one_comment', 20);
这里没无限制治理员的评论次数,那咱们顺带着看一下判别用户能否为治理员的办法:
判别指定id的用户是不是治理员
该需要完成起来十分简略,几行代码搞定,分享一下:
function ludou_is_administrator($user_id) { $user = get_userdata($user_id); if(!empty($user->roles) && in_array('administrator', $user->roles)) return 1; // 是治理员 else return 0; // 非治理员 }
判别以后登录用户是不是治理员
假如是判别以后登录用户是不是治理员,能够应用上面的函数:
function ludou_is_administrator() { // wp_get_current_user函数仅限在主题的functions.php中应用 $currentUser = wp_get_current_user(); if(!empty($currentUser->roles) && in_array('administrator', $currentUser->roles)) return 1; // 是治理员 else return 0; // 非治理员 }
以上就是安达网络工作室关于《WordPress中限制非管理员用户在文章后只能评论一次》的一些看法。更多内容请查看本栏目更多内容!
复制代码代码如下: /* Theme Name: 这里填主题称号 Theme URI: 这里填主题引见的网址,没有就填你的博客网址...
本文实例讲述了WordPress完成搜寻后果包括自定义文章类型内容的办法。分享给大家供大家参考。详细剖析如下:...
明天忽然有个网友留言说博客的Feed挂了,症状如下: Chrome间接关上订阅页面显示如下: This page contain...
wp_parse_args() 函数是 WordPress 外围常常用到的函数,它的用处很多,但最次要用来给一个数组参数(args)...
comments_template()(获取评论模板) comments_template() 函数用来获取评论模板,普通只能用在文章或许页...
WORDPRESS博客站曾经运转快一年了,在伪动态上不断很纠结,空间默许不支持伪动态,网上找了很多办法,用404...