7

我收到了这个奇怪的错误。你会说:“为什么奇怪?你只是没有这样的属性”。不,问题是有财产

我得到了一个错误。

// PHP Notice:  Undefined property: stdClass::$roles in
$canWrite = $this->session->isLoggedIn() ? $this->page->canWrite($this->session->user->roles) : false;

这是课堂。

class User {
    protected $roles;

    function getRoles() {
        if (!$this->roles)
        {
            // Get them!
        }

        return $this->roles;
    }
}

因此,当我尝试访问此行中的属性时,将调用此方法。一切正常,但我不想增加我的错误日志。发生了什么?

UPD1

$this->user->session是一个User对象

function getUser() {
    if (!$this->user) {
        $u = new User();
                    // Logic
        $this->user = $u;
    }
    return $this->user;
}
User Object
(
    [roleId:protected] => 1
    [roles:protected] => Array
        (
            [root] => Role Object
                (
                    [id:protected] => 1
                    [hrefname:protected] => root
                )

        )
)

UPD2

所有属性都可以通过魔法访问__get()

public function __get($var) {
    if ($this->__isset($var)) {
        $method = 'get'.ucfirst($var);
        if (method_exists($this, $method)) {
            return $this->$method();
        } else {
            return $this->$var;
        }
    }
    throw new Exception("Unrecognized attribute '$name'");
}

UPD3

var_dump($this->session->user)

object(User)#370 (30) {
  ["roles":protected]=>
  array(1) {
    ["root"]=>
    object(Role)#372 (2) {
      ["id":protected]=>
      string(1) "1"
      ["hrefname":protected]=>
      string(4) "root"
    }
  }
}

解释

在一个地方,我不小心写在尚未创建$this->session->user->id = $user->id的地方。原来$this->session->user如此。好吧,谢谢你,PHPnull->id(new stdClass())->id

4

2 回答 2

5

因为它说未定义的属性是 in stdClass,这意味着有问题的对象实际上不是User您认为的类。

这通常意味着创建对象时出现了问题。因此,导致此错误的代码中的实际错误在程序中比您给我们的代码行更早。

查找创建对象的位置。这就是问题所在。

如果没有看到其余的代码,我无法提供比这更多的帮助,但希望能有所帮助。

[编辑]

引发错误的对象是$this->session->user(这是您尝试访问其->roles属性的对象)。

尽管您想说它绝对是一个User对象,但事实是 PHP 另有说明。在错误之前立即执行var_dump($this->session->user),您应该能够看到我在说什么。

至于为什么不是你所期望的,我仍然无法给出更好的答案。使用像xDebug这样的调试器一次一行地跟踪程序可能会有所帮助。

于 2012-10-07T19:35:29.210 回答
2

显而易见的解释是该属性已定义,但受到保护。这意味着它只能被这个类和扩展类访问。

但是,错误消息确实暗示了其他一些错误。该类是一个User类,但错误表明它是stdClass.

于 2012-10-07T19:33:51.803 回答