WordPress如何判断登录用户的角色

在WordPress主题或者插件开发的过程中,经常要遇到判断登录用户的角色,并根据不同的用户角色赋予不同的权限。下面总结两种比较常用的判断方法。

一、使用 current_user_can() 判断

current_user_can() 可以根据不同角色拥有的权限来判断用户角色,具体的用户权限,可以在Roles and Capabilities 中找到。

判断用户是否为管理员(Administrator)

判断用户是否为编辑(Editor)

判断用户是否为作者(Author)

判断用户是否为投稿者(Contributor)

判断用户是否为订阅者(Subscriber)

二、使用$current_user判断

$current_user是WordPress的一个全局变量,当用户登录后,这个里面就会有用户的角色和权限信息。

当WordPress的init action执行后,就可以安全的使用$current_user全局变量了。

在模板文件中判断登录用户是否为作者(Author)

在functions.php中判断用户是否为作者(Author)

之所以要使用

是因为$current_user这个全部变量到init action执行时才完成赋值,既然要读它的内容,至少要等到它的内容准备好后再读取。functions.php的代码先与init action执行,所以在functions.php中直接写global $current_user是无法获取用户信息的。

检查用户角色之前,还可以先检查一下用户是否登录

更简单的方法

还有一种更直接的方法,例如判断当前用户是否为管理员

发表评论

电子邮件地址不会被公开。 必填项已用*标注