如何在PHP中捕获对对象的任何方法调用?

如何在PHP中捕获对对象的任何方法调用?,php,object,interception,Php,Object,Interception,我试图找出如何捕获PHP中对象上调用的任何方法。我知道神奇的函数\uuu call,但它只对被调用对象上不存在的方法触发 例如,我有这样的东西: class Foo { public function bar() { echo 'foobar'; } public function override($method_name,$method_args) { echo 'Calling method ',$method_name,'<br />';

我试图找出如何捕获PHP中对象上调用的任何方法。我知道神奇的函数
\uuu call
,但它只对被调用对象上不存在的方法触发

例如,我有这样的东西:

class Foo
{
  public function bar()
  {
    echo 'foobar';
  }

  public function override($method_name,$method_args)
  {
    echo 'Calling method ',$method_name,'<br />';
    $this->$method_name($method_args); //dirty, but working
  }
}
class Foo 
{
    public function bar() {
        echo 'foobar';
    }
}

class Decorator 
{
    protected $foo;

    public function __construct(Foo $foo) {
       $this->foo = $foo;
    }

    public function __call($method_name, $args) {
       echo 'Calling method ',$method_name,'<br />';
       return call_user_func_array(array($this->foo, $method_name), $args);
    }
}

$foo = new Decorator(new Foo());
$foo->bar();
我想要这个输出:

Calling method bar
foobar
而不是这个:

foobar

有没有办法做到这一点?请提供帮助:)

您可以在对象周围环绕一个对象,拦截任何调用,然后在原始对象上转发它们并返回结果

只需将对象作为变量存储在包装器类中,并在包装器类中使用重载方法来调用/设置/获取/检查对象

$object = new AnyObject;
$object = new Wrapper($object);

$object->anyMethod();
$object->anyVar = 'test';
echo $object->anyVar;
echo $object['array form'];

在foreach中循环包装器类可能更难。还没有尝试过。

使用原始的
Foo
实现,您可以像这样在其周围包装一个
装饰器:

class Foo
{
  public function bar()
  {
    echo 'foobar';
  }

  public function override($method_name,$method_args)
  {
    echo 'Calling method ',$method_name,'<br />';
    $this->$method_name($method_args); //dirty, but working
  }
}
class Foo 
{
    public function bar() {
        echo 'foobar';
    }
}

class Decorator 
{
    protected $foo;

    public function __construct(Foo $foo) {
       $this->foo = $foo;
    }

    public function __call($method_name, $args) {
       echo 'Calling method ',$method_name,'<br />';
       return call_user_func_array(array($this->foo, $method_name), $args);
    }
}

$foo = new Decorator(new Foo());
$foo->bar();
class-Foo
{
公共功能条(){
回声“foobar”;
}
}
班级装饰员
{
受保护$foo;
公共函数构造(Foo$Foo){
$this->foo=$foo;
}
公共函数调用($method\u name,$args){
回显“调用方法”,$method_name,“
”; 返回call\u user\u func\u数组(数组($this->foo,$method\u name),$args); } } $foo=newdecorator(newfoo()); $foo->bar();
如果您将函数设置为private,则调用将捕获从外部对其进行的任何调用都将捕获在_调用中,但您可以从内部调用它

class Foo
{
   private function bar()
   {
      echo 'foobar';
   }

   public function __call($method_name,$method_args)
   {
      echo 'Calling method ',$method_name,'<br />';
      $this->$method_name(); //dirty, but working
   }
}
class-Foo
{
专用功能条()
{
回声“foobar”;
}
公共函数调用($method\u name,$method\u args)
{
回显“调用方法”,$method_name,“
”; $this->$method_name();//脏,但仍在工作 } }
您能更具体一点吗?只是一个小例子:)谢谢,伙计,这正是我所需要的:)一个不起作用的例子是,如果你的方法期望
Foo
,例如
someMethod(Foo$Foo)