PHP 错误可以写入数据库而不是错误日志文件吗?
PHP 错误通常记录到标准 error_log 文件中,但可能希望将它们存储在数据库中,以便更容易跟踪和分析。虽然如果不创建自定义错误处理程序,这不可能直接实现,但可以通过单个全局更改来实现。
实现自定义错误处理程序
控制的关键处理错误的方式是创建自定义错误处理程序。这可以使用 set_error_handler() 函数来完成,该函数将回调函数作为其参数。回调函数应具有以下签名:
function error_handler($errno, $errstr, $errfile, $errline) {}
在回调函数内,您可以确定应如何处理每个错误,包括是否将其记录到数据库。
将错误记录到 MySQL 的示例
以下代码显示了将 PHP 错误记录到 MySQL 数据库的自定义错误处理程序的示例:
function myErrorHandler($errno, $errstr, $errfile, $errline) { // Establish connection to MySQL database $conn = mysqli_connect("hostname", "username", "password", "database"); // Prepare SQL query to log error $query = "INSERT INTO error_log (number, string, file, line) VALUES (?, ?, ?, ?)"; $stmt = mysqli_prepare($conn, $query); // Bind parameters to SQL query mysqli_stmt_bind_param($stmt, "isss", $errno, $errstr, $errfile, $errline); // Execute SQL query to log error mysqli_stmt_execute($stmt); // Close database connection mysqli_close($conn); // Don't execute PHP internal error handler return true; } // Set user-defined error handler $old_error_handler = set_error_handler("myErrorHandler");
设置用户定义后错误处理程序,所有 PHP 错误都将通过您的自定义错误处理逻辑进行路由,包括记录到 MySQL 数据库。
以上是可以将 PHP 错误存储在数据库中而不是日志文件中吗?的详细内容。更多信息请关注PHP中文网其他相关文章!