我从一个不引用Debugger类的文件中获取标题中引用的错误。如果我手动导入调试器,则错误仍会显示。在结尾的错误中引用的行号结束文件中的类定义。没有任何内容跟}}(没有?>)。我收到错误的文件并没有直接引用调试器,因为我可以告诉(因为没有明确使用调试器)。
这是堆栈跟踪:
( ! ) Fatal error: Class 'Debugger' not found in /home/gregg/workspace/Fueled/dapprly/backend/app/Plugin/Facebook/Controller/Component/FapiComponent.php on line 107
Call Stack
# Time Memory Function Location
1 0.0003 245664 {main}( ) ../index.php:0
2 0.0168 1657712 Dispatcher->dispatch( ) ../index.php:100
3 0.0237 2753568 Dispatcher->_invoke( ) ../Dispatcher.php:85
4 0.0237 2753768 Controller->constructClasses( ) ../Dispatcher.php:99
5 0.0237 2755712 ComponentCollection->init( ) ../Controller.php:638
6 0.0255 3057112 ComponentCollection->load( ) ../ComponentCollection.php:52
7 0.0255 3057600 class_exists ( ) ../ComponentCollection.php:99
8 0.0255 3057896 App::load( ) ../ComponentCollection.php:0
9 0.0257 3091416 ErrorHandler::handleError( ) ../ComponentCollection.php:551
这是第107行的背景:
class FapiComponent extends Component {
// -- snip -- //
public function method()
{
$url = urlencode('http://url');
$param = array(
'access_token' => '##' ,
'object' => 'user',
'fields' => 'feed',
'callback_url' => $url);
$id = $this->facebook->getAppId();
$subs = $this->facebook->api('/' . $id . '/subscriptions' , 'POST' , $param);
}
} // <-- line 107 ... nothing after this
答案 0 :(得分:13)
这是由于PHP bug未对编译时错误执行自动加载(例如E_STRICT
)。
这在PHP 5.4.21中得到修复,CakePHP接受了workaround pull request。
手动解决此问题并从CakePHP的错误处理程序中免除E_STRICT
:
core.php
(您可以通过执行find . -name core.php
之类的操作找到该文件。'level' => E_ALL & ~E_DEPRECATED,
'level' => E_ALL & ~E_DEPRECATED & ~E_STRICT,
答案 1 :(得分:8)
我发现了错误。
我所展示的这个类已经实现了initialize方法。但它实现为
public function initialize($controller)
这是一个E_STRICT错误,因为它与父方法的区别在于省略了类型提示。我的设置是捕获E_STRICT错误。此错误导致它查找调试器。我不确定为什么它不能自动加载它,而是将方法改为
public function initialize(Controller $controller)
解决了我遇到的问题。
答案 2 :(得分:0)
每次出现E_STRICT错误时都会发生这种情况。我的主要功能是运行PHP 5.4时,您需要公共,私有和受保护的函数声明。
答案 3 :(得分:0)
问题是,低于版本5.4.21的php在E_STRICT错误上出现自动加载器问题。 (E_STRICT是编译时错误)
https://bugs.php.net/bug.php?id=65322
我在一些旧项目中遇到了完全相同的问题,并在2.7.4中修复了它。
https://github.com/cakephp/cakephp/issues/7376
所以真正的解决方案是升级到至少5.4.21或等待CakePHP 2.7.4