任何人都无法阐明为什么我可以进行此工作。
我想查询一个数组,以查看当前登录的USER->id
是否被分配了特定角色:
$contextroles = get_records_sql("SELECT userid FROM {$CFG->prefix}role_assignments WHERE contextid = 23 AND roleid = 3");
function object2array($object) {
if (is_object($object)) {
foreach ($object as $key => $value) {
$array[$key] = $value;
}
}
else {
$array = $object;
}
return $array;
}
$alloweduser = object2array($contextroles);
if (in_array($USER->id, $alloweduser)) {
echo'Your in<br />';
echo $USER->id.'<br />';
print_r($alloweduser);
}
else{
echo'<br />You do not have permission to acces this database.<br />';
echo $USER->id.'<br />';
print_r($alloweduser);
exit;
}
我目前正在获得以下输出:
如您所见,5410在阵列中,因此不应拒绝访问。
在此先感谢您的帮助。
最佳答案
因为是5410 != stdClass Object ( [userid] => 5410 )
(如果使用in_array()
)。
由于您的数组键看起来与userid
相同,因此您只需要使用isset($alloweduser[$USER->id])
即可。