记录PHP错误日志 display_errors与log_errors的区别


在PHP中,`display_errors` 和 `log_errors` 是两个用于控制错误报告行为的配置项,它们的作用和区别如下:

### `display_errors`

- **作用**:控制是否将错误信息作为输出的一部分显示给用户。

- **值**:可以设置为 `On` 或 `Off`。

- **当设置为 `On` 时**:如果脚本执行中遇到错误,这些错误信息会直接显示在浏览器中(对于Web应用)或在命令行中(对于CLI脚本)。

- **当设置为 `Off` 时**:错误信息不会被直接显示给用户,而是根据 `log_errors` 的设置决定是否记录到日志文件中。

### `log_errors`

- **作用**:控制是否将错误信息记录到日志文件中。

- **值**:可以设置为 `On` 或 `Off`。

- **当设置为 `On` 时**:PHP会将错误信息记录到指定的错误日志文件中(由 `error_log` 配置项指定)。

- **当设置为 `Off` 时**:错误信息不会被记录到日志文件中,除非 `display_errors` 被设置为 `On`,此时错误信息会被直接显示给用户(如果适用)。

### 区别总结

- **显示给用户**:`display_errors` 控制是否将错误信息直接显示给用户。

- **记录到日志**:`log_errors` 控制是否将错误信息记录到日志文件中。

- **交互关系**:即使 `display_errors` 被设置为 `Off`,如果 `log_errors` 被设置为 `On`,错误仍然会被记录到日志文件中,但不会直接显示给用户。反之,如果 `log_errors` 被设置为 `Off`,即使 `display_errors` 被设置为 `On`,错误信息也不会被记录到日志文件中,但会直接显示给用户(如果适用)。

在开发环境中,为了调试方便,通常会设置 `display_errors` 为 `On` 和 `log_errors` 为 `On`,以便在显示错误信息的同时也将它们记录到日志文件中。而在生产环境中,为了避免敏感信息泄露,通常会设置 `display_errors` 为 `Off` 并保持 `log_errors` 为 `On`,以便在不影响用户体验的情况下记录错误信息供后续分析和处理。