php判断用户和管理员,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']);

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值