TP3.*系列版本偶尔会出现Class ‘ThinkLog’ not found的奇葩问题,解决办法有两种,具体如下:

1.临时解决办法:删除缓存文件:Runtime/common~runtime.php

2.完美解决办法(适用于方法1无法解决的情况下):

其实出现这个问题的原因是php5.3版本bug(PHP 5.4.21已经fixed这个bug),set_error_handler处理函数无法调用spl_autoload_register来自动加载Log类的问题。

因此我们升级代码运行环境到PHP 5.4.21以上版本即可完美解决这个问题,如果不方便升级PHP版本的话,可以在error_handler之前预先加载Log类也可以完美解决这个问题,具体步骤如下:

打开文件:ThinkPHP/Library/Think/Think.class.php,定位到Storage::connect(STORAGE_TYPE);处,在后面添加一行代码

version_compare(PHP_VERSION, '5.4.21', '<') && Log::INFO;

BUG参考:

http://stackoverflow.com/questions/1942507/set-error-handler-function-not-calling-autoload]