gpt4 book ai didi

php - 来自 mysql_connect() 的警告未填充 mysql_error()

转载 作者:行者123 更新时间:2023-11-29 02:34:35 26 4
gpt4 key购买 nike

环境-PHP5.2.17、MySQL5.0.92

我在我的应用程序中实现了一个错误日志记录框架,我正在尝试将错误和警告记录到数据库中。

$db = mysql_connect('host', 'database', 'password');
if (!$db)
{
log(mysql_error());
}
...continue code

我想测试日志记录并将错误的主机传递给 mysql_connect 函数。正如预期的那样,我在屏幕上收到了警告

Warning: mysql_connect() [function.mysql-connect]: Unknown MySQL server host 'host' (1) in /path/to/my/php/file.php on line 4

并且调用了我的日志函数,但 mysql_error() 为空。根据 php 手册 (http://php.net/manual/en/function.mysql-connect.php),mysql_error() 应该返回最后一个 mysql 错误。在手册中,他们甚至有一个示例,说明如何使用 mysql_error() 将错误回显到屏幕上。

我尝试使用 mysql_error($db),但它返回一个错误,指出 $db 未定义。

我尝试用 echo mysql_error(); 替换我的函数;我什么也没显示。

我尝试使用 mysql_errno();我也得到 null。

我知道脚本正在捕获警告,因为它正在将警告输出到屏幕。

解决我的问题的一种方法是将警告存储在变量中。

我感谢任何人可以提供的帮助。谢谢。

更新 - 2 个解决方案:

解决方案 1:(感谢马里奥在他对这篇文章的评论之一中提出了这个建议)

使用 PHP 函数 error_get_last() - 引用 (http://php.net/manual/en/function.error-get-last.php)。

此解决方案的新工作代码:

$db = mysql_connect('host', 'database', 'password');
if (!$db)
{
$error = error_get_last();
log($error['type'] . ": " . $error['message'] . " in file " . $error['file'] . " on line " . $error['line']);
}
...continue code

解决方案 2:(感谢 PauPRO 在下面的答案 1 中提出此建议)

在使用$php_errormsg之前,我们需要在php.ini文件中将track_errors设置为1。只需在您的 php.ini 文件中包含以下行

track_errors = 1

或者,您可以在脚本中将 track_errors 设置为 1,请参阅下面的代码:

ini_set('track_errors', 1);
$db = mysql_connect('host', 'database', 'password');
if (!$db)
{
log(mysql_error());
}
...continue code

两种解决方案都有效!!!

最佳答案

确保在使用 $php_errormsg 之前打开 track_errors:

// Preferably do this in your php.ini file, instead of in code.
ini_set('track_errors', 1);

$db = mysql_connect('host', 'database', 'password');
if (!$db)
{
log($php_errormsg);
}

关于php - 来自 mysql_connect() 的警告未填充 mysql_error(),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7277830/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com