CodeIgniter - 错误处理



很多时候,在使用应用程序时,我们会遇到错误。如果错误没有得到妥善处理,对用户来说是非常恼人的。CodeIgniter 提供了一种简单的错误处理机制。

您希望在应用程序处于开发模式而不是生产模式时显示这些消息,因为错误消息可以在开发阶段轻松解决。

可以通过更改以下 index.php 文件中的行来更改应用程序的环境。这可以设置为任何值,但通常为此目的使用三个值(开发、测试、生产)。

define('ENVIRONMENT', isset($_SERVER['CI_ENV']) ? $_SERVER['CI_ENV'] : 'development');

不同的环境需要不同级别的错误报告。默认情况下,开发模式将显示错误,而测试和生产模式将隐藏它们。CodeIgniter 提供了如下所示的三个函数来处理错误。

  • show_error() 函数以 HTML 格式在屏幕顶部显示错误。

语法

show_error($message, $status_code, $heading = 'An Error Was Encountered')

参数

  • $message (混合) - 错误消息

  • $status_code (整数) - HTTP 响应状态码

  • $heading (字符串) - 错误页面标题

返回值类型

混合
  • show_404() 函数在您尝试访问不存在的页面时显示错误。

语法

show_404($page = '', $log_error = TRUE)

参数

  • $page (字符串) – URI 字符串

  • $log_error (布尔) – 是否记录错误

返回值类型

  • log_message() 函数用于写入日志消息。当您想要编写自定义消息时,这很有用。

语法

log_message($level, $message, $php_error = FALSE)

参数

  • $level (字符串) - 日志级别:'error'、'debug' 或 'info'

  • $message (字符串) - 要记录的消息

  • $php_error (布尔) - 我们是否正在记录本机 PHP 错误消息

返回值类型

可以在 application/config/config.php 文件中启用日志记录。以下是 config.php 文件的屏幕截图,您可以在其中设置阈值。

/*
|--------------------------------------------------------------------------------
|   Error Logging Threshold
|--------------------------------------------------------------------------------
| You can enable error logging by setting a threshold over zero. The 
| threshold determines what gets logged. Threshold options are:
|
|   0 = Disable logging, Error logging TURNED OFF
|   1 = Error Message (including PHP errors)
|   2 = Debug Message
|   3 = Informational Messages
|   4 = All Messages
|
| You can also pass an array with threshold levels to show individual error types
|
|   array(2) = Debug Message, without Error Messages
| For a live site you'll usually only enable Errors (1) to be logged otherwise 
| your log files will fill up very fast.
|
*/
$config['log_threshold'] = 0;

您可以在 application/log/ 中找到日志消息。在启用日志文件之前,请确保此目录可写。

可以在 application/views/errors/cliapplication/views/errors/html 中找到各种错误消息模板。

广告

© . All rights reserved.