如何在 thinkphp 中获取类似 laravel 的详细错误日志
laravel 框架以清晰地打印异常而著称,便于开发人员快速定位错误。然而,thinkphp 默认打印的异常信息却令人难以阅读。本文将介绍如何在 thinkphp 中打印具有函数输入参数、错误行数和错误原因的详细错误日志。
使用 __tostring() 方法
thinkphp 抛出的异常实现了 __tostring() 方法,该方法可以返回一个包含异常详细信息的字符串。例如:
立即学习“PHP免费学习笔记(深入)”;
try { $a = 1 / 0; } catch (throwable $e) { log::info($e->__tostring()); }
打印的结果与 laravel 中类似,包括函数调用栈、错误行数和错误原因。
其他方法
除了 __tostring() 方法,还可以使用以下方法来获取更详细的错误信息:
- $e->getfile():获取错误发生的源文件。
- $e->getline():获取错误发生的源文件行号。
- $e->getmessage():获取错误消息。
- $e->getcode():获取错误代码。
示例代码
try { $a = 1 / 0; } catch (Throwable $e) { Log::info('错误文件:' . $e->getFile()); Log::info('错误行号:' . $e->getLine()); Log::info('错误消息:' . $e->getMessage()); Log::info('错误代码:' . $e->getCode()); }
以上代码将打印更详细的错误信息,包括错误文件、错误行号、错误消息和错误代码。