如何限制非管理员用户在一篇文章后只能评论一次
本文主要介绍如何限制非管理员用户在文章后评论一次wordpress建站,希望能解决大家遇到的相关问题,一起来看看吧看看这篇“文章后如何限制非管理员用户”只能评论一次”的文章。
先不说这个需求有没有用,毕竟是针对各种需求的人。这个功能实现起来也比较简单。就在用户发表的每条评论进入数据库之前,需要检查是否同一个用户名或电子邮件地址已经从当前文章的所有评论中发表了评论,如果是,则跳转到错误页面。 .
实现代码可以放在当前主题的.php中(这里也加上IP判断wordpress网站建设,更安全):
// 获取评论用户的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('本站每篇文章只允许评论一次。点此返回');
}
return $commentdata;

}
add_action( 'preprocess_comment' , 'ludou_only_one_comment', 20);
管理员发表的评论数没有限制wordpress管理员密码,下面我们来看看判断用户是否为管理员的方法:
判断指定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管理员密码,希望能解决大家遇到的问题。我们来看看这篇文章《隐藏和部分显示用户登录框密码的方法》。 ...
文章来自互联网,侵权请联系删除,文章阐述观点来自文章出处,并不代表本站观点。
www.8001717.cn