7

任何人都可以解释为什么我可以让这个工作。
我想查询一个数组以查看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

数组 ( [7] => stdClass 对象 ( [userid] => 7 ) [9] => stdClass 对象 ( [userid] => 9 ) [27] => stdClass 对象 ( [userid] => 27 ) [98] => stdClass 对象 ( [userid] => 98 ) [203] => stdClass 对象 ( [userid] => 203 ) [252] => stdClass 对象 ( [userid] => 252 ) [5410] => stdClass 对象 ( [用户名] => 5410 ) )

如您所见,5410 在数组中,因此不应被拒绝访问。提前感谢您的帮助。

4

1 回答 1

3

因为5410 != stdClass Object ( [userid] => 5410 )如果你使用in_array().

由于您的数组键看起来与 相同userid,因此您只需使用它isset($alloweduser[$USER->id])

于 2011-09-01T13:54:26.147 回答