首先,问问自己究竟什么定义了“拥有root权限”的登录名. AFAICT有2种基本解决方案.
老派的方式,系统管理员用uid 0创建多个帐户,而我 – 我当然不是一个人 – 认为这是一场噩梦.在这种情况下,您可以使用posix_getpwnam检查列表中的所有用户,并查看他们的uid是否匹配0.
以下代码片段就是这样,$privileged将包含具有root权限的用户:
$logins = array('root', 'john', 'guest', 'foo');
$privileged = array();
foreach($logins as $login) {
$userInfo = posix_getpwnam($login);
if ($userInfo !== FALSE) {
if ($userInfo['uid'] == 0) {
$privileged[] = $login;
}
}
}
另一种(和imho唯一理智)方法是将具有root /管理权限的所有用户添加到特定组(轮盘或管理员已经在不同的Linux发行版中使用,找出哪一个适合您).这种情况甚至更简单,因为您可以使用posix_getgrnam来获取特定组中的所有成员.
以下代码段将匹配您提供的登录数组,并查看谁是具有特定权限的成员,同时$privileged将包含结果(即列表中的用户是您指定的组的成员):
$logins = array('root', 'john', 'guest', 'foo');
$privileged = array();
$groupInfo = posix_getgrnam('admins');
if ($groupInfo !== FALSE) {
$privileged = array_intersect($logins, $groupInfo['members']);
}