FuelPHP 错误

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

Error Handling

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

File Not Found Error

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

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

'_404_'   => 'welcome/404',    // The main 404 route 

Internal Errors

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

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

'_500_'   => 'welcome/500',    // The main 500 route

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

Access Violation Errors

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

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

'_403_'   => 'welcome/403',     // The main 403 route 

此页面将显示访问违规信息。

Debugging

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

Debug Class

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

下一章:FuelPHP 单元测试

 单元测试是开发大型项目的必要过程。 单元测试有助于在开发的每个阶段自动测试应用程序的组件。当应用程序的组件没有根据项目的业务规范工作时,它会发出警报。单元测试可以手动完成,但通常是自动化的。  ...