FuelPHP - 错误处理和调试

FuelPHP 为处理错误和调试应用程序提供了出色的支持。让我们在本章中了解错误处理和调试。

错误处理

FuelPHP 错误处理基于异常。FuelPHP 为所有旧 php 错误提供 PhpErrorException 异常。每当遇到 PHP 代码中的错误时,FuelPHP 都会引发 PhpErrorException。FuelPHP 还可以轻松显示各种 HTTP 状态代码的自定义错误页面。

文件未找到错误

FuelPHP 提供了一个新的异常类 HttpNotFoundException 来处理未知请求。有时,我们可能会遇到可能无法处理的请求。那时,我们只需抛出 HttpNotFoundException 即可。

默认情况下,在路由配置文件 fuel/app/config/routes.php 中,使用 400 条目为 HttpNotFoundException 配置了一个默认页面。每当引发 HttpNotFoundException 时,请求都会重定向到 400 页面。

'_404_' => 'welcome/404', // 主 404 路由

内部错误

FuelPHP 提供了一个新的异常类 HttpServerErrorException 来处理所有服务器错误。有时,我们可能由于内部错误而无法处理给定的请求。那时,我们只需抛出 HttpServerErrorException 即可。

默认情况下,在路由配置文件 fuel/app/config/routes.php 中,使用 500 条目为 HttpServerErrorException 配置了一个默认页面。每当引发 HttpServerErrorException 时,请求都会重定向到 500 页面。

'_500_' => 'welcome/500', // 主 500 路由

此页面将记录错误,在页面中显示格式化的错误,并偶尔向系统管理员发送通知。

访问冲突错误

FuelPHP 提供了一个新的异常类 HttpNoAccessException 来处理访问冲突。有时,我们可能由于访问限制而无法处理请求。那时,我们只需抛出 HttpNoAccessException 即可。

默认情况下,在路由配置文件 fuel/app/config/routes.php 中,使用 403 条目为 HttpNoAccessException 配置了一个默认页面。每当引发 HttpNoAccessException 时,请求都会重定向到 403 页面。

'_403_' => 'welcome/403', // 主 403 路由

此页面将显示访问冲突信息。

调试

调试是开发应用程序最常见的活动之一。FuelPHP 提供了一个简单的类 Debug 来处理应用程序的调试活动。本章我们来学习Debug类及其方法。

Debug类

Debug类提供了实用方法来显示变量、对象、数组等的详细信息。Debug类提供了以下方法,

dump

dump方法以格式化的结构化方式向浏览器返回多个混合值。

Debug::dump($var1, $var2);

backtrace()

backtrace 显示有关当前代码执行的详细信息。它显示 PHP 文件信息、当前行及其所有先前的操作。

Debug::backtrace();

classes()

返回所有类的列表。

Debug::classes();

interfaces()

返回所有接口类的列表。

Debug::interfaces();

includes()

返回当前在运行时加载的所有包含文件的列表。

Debug::includes();

functions()

返回所有函数的列表。

Debug::functions();

constants()

返回所有常量的列表。

Debug::constants();

extensions()

返回所有扩展的列表。

Debug::extensions();

headers()

返回所有 HTTP 标头的列表。

Debug::headers();

phpini()

打印从 php.ini 文件读取的配置设置列表。

Debug::phpini();