如何验证用户是否是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 举报,一经查实,本站将立刻删除。