微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

php – 检查用户是否是root用户

如何验证用户是否是PHP脚本中的root用户?命令是什么?
我试过这样的事情:

exec("su -l login < `echo password`");

但是su命令无法接收密码……

请注意,该计算机与Internet隔离,因此我可以根据需要以root身份运行PHP.

编辑:
我不想知道运行该脚本的当前用户是否是root用户.
我的PHP脚本中有一个用户列表,如果他有root权限,我想知道每次登录.

解决方法:

首先,问问自己究竟什么定义了“拥有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']);
}

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐