1

我仅将 log4php 库日志错误用于控制台(stdout)。但是当我在浏览器上运行我的代码时,它会在浏览器上输出,这是我不希望发生的。

我已经提到并尝试了 记录 php 错误但没有在浏览器中显示它,但是这些答案都没有为我解决我的代码很简单。

<?php
error_reporting(E_ERROR | E_PARSE);
error_reporting(0);ini_set('display_errors', 'Off');
require_once("log4php/Logger.php");
$logger = Logger::getLogger("main");
$logger->info("This is an informational message.");
$logger->warn("I'm not feeling so good...");

配置文件:

<configuration xmlns="http://logging.apache.org/log4php/">
<appender name="default" class="LoggerAppenderConsole">
    <layout class="LoggerLayoutSimple" />
</appender>
<root>
    <appender_ref ref="default" />
</root>

这在浏览器上输出,

INFO - 这是一条信息性消息。警告 - 我感觉不太好......

我希望它只在标准输出上。在这种情况下,如果我对 stodut 的理解有误,请告诉我

回答后编辑我的工作代码:

<?php
require_once("log4php/Logger.php");
Logger::configure("log4php/config.xml");
$logger = Logger::getLogger("default");
$logger->info("This is an informational message.");
$logger->warn("I'm not feeling so good...");
4

2 回答 2

1

我认为您没有以正确的方式调用文件!或缺少 xml 文件

require_once('/path/to/log4php.xml');

所以应该是这样的

error_reporting(E_ERROR | E_WARNING | E_PARSE);
error_reporting(0);
ini_set('display_errors', 'Off');
require_once('/path/to/log4php/Logger.php');
//xml file here
$logger = Logger::getLogger(basename(__FILE__));
$logger->info('This is an informational message');
$logger->warn("I'm not feeling so good...");

看到这个问题很好:log4php:无法创建日志文件

于 2020-01-22T14:07:58.333 回答
0

尝试

ini_set('display_errors',0);

或在 php.ini 文件中设置该指令

https://www.php.net/manual/en/errorfunc.configuration.php#ini.display-errors

在它说的文档中 Although display_errors may be set at runtime (with ini_set()), it won't have any effect if the script has fatal errors. This is because the desired runtime action does not get executed.

于 2020-01-22T14:04:33.213 回答