任何人都无法阐明为什么我可以进行此工作。
我想查询一个数组,以查看当前登录的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])即可。

10-05 20:29
查看更多