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();