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]
声明:1、本博客不从事任何主机及服务器租赁业务,不参与任何交易,也绝非中介。博客内容仅记录博主个人感兴趣的服务器测评结果及一些服务器相关的优惠活动,信息均摘自网络或来自服务商主动提供;所以对本博客提及的内容不作直接、间接、法定、约定的保证,博客内容也不具备任何参考价值及引导作用,访问者需自行甄别。2、访问本博客请务必遵守有关互联网的相关法律、规定与规则;不能利用本博客所提及的内容从事任何违法、违规操作;否则造成的一切后果由访问者自行承担。3、未成年人及不能独立承担法律责任的个人及群体请勿访问本博客。4、一旦您访问本博客,即表示您已经知晓并接受了以上声明通告。







