-1

我有一个名为“logToFile”的函数,我正在尝试调用它,但 PHP 认为我正在尝试重新声明它。

日志文件:

function logToFile($msg) {
$filename = "log.txt";
$fd = fopen($filename, "a");
$str = "[" . date("Y/m/d h:i:s", mktime()) . "] " . $msg;
fwrite($fd, $str . "\n");
fclose($fd);

我对函数的调用:

logToFile("$user->username kicked $arg1 for $arg2.");

请帮忙?

4

1 回答 1

5

好吧,PHP 并不愚蠢。如果 PHP 说您正在重新声明一个函数,那么您就是。当函数定义多次出现时,PHP 会抛出一个 Fatal 错误,类似如下:

致命错误:无法在第 Y 行的 /path/to/script 中重新声明 logToFile()(之前在 /path/to/script: X声明)

在这里, X 是您最初声明函数的行,而 Y 是您尝试重新声明(不是call,正如您在问题中声明的那样)函数的位置。检查您的代码以找到此行并将其删除。

为了避免这样的错误,你可以先检查一个函数是否是使用定义的function_exists(),然后尝试声明它:

if (!function_exists('logToFile')) {
    function logToFile($msg) {
        $filename = "log.txt";
        $fd = fopen($filename, "a");
        $str = "[" . date("Y/m/d h:i:s", mktime()) . "] " . $msg;
        fwrite($fd, $str . "\n");
        fclose($fd);
    }
} else {
    echo 'Trying to re-declare the function';
}

虽然上述方法将帮助您避免致命错误,但我强烈建议您找出重新定义函数的位置并改正它。大多数情况下,这将是由于包含您的函数的文件的多个包含。在这种情况下,您可以简单地使用require_once()。PHP 将检查文件是否已经被包含,如果是,则不再包含(要求)它。

于 2013-11-03T17:28:10.790 回答