如何在我的脚本中拦截PHP函数调用?

时间:2014-02-01 18:05:38

标签: php function

我知道我可以使用__call魔术方法拦截对象的方法调用。但是我如何拦截PHP函数(用PHP构建或用户定义)调用我的脚本部分?

例如,我有一些代码:

echo "Hello world";
$s = 0;
$i = $i + 5;
$str = str_repeat('Hi ', $i);
$hash = md5($str);
print $a;

我需要拦截str_repeat()函数调用并且不执行它以及之后的所有代码并返回一些错误(或者只是执行die('error');),这是真的吗?

1 个答案:

答案 0 :(得分:1)

你检查了这个:http://www.java2s.com/Code/Php/Class/InterceptingMethodCallswiththecallMethodPHP5Only.htm

这并不复杂,但你需要修改一些代码才能这样做。

您还可以创建自己的函数来进行回调,而不是调用函数/方法,您可以通过自己的拦截函数

PSEUDO CODE

function myFakeFunction(...){ ... }

function runFunction($functionName){
  // DO WHAT YOU WANT: INTERCEPTION
  call_user_func($functionName);
}
runFunction("myFakeFunction", ...);
在文档中

call_user_func

注意:您应该关注这两种方法的安全问题。

编辑:我只是有了一个新想法,您还可以为要检查的所有方法创建一个共享对象,并在该对象上使用_call。但我不确定这是否会正常工作。