PHP在异常堆栈跟踪中缺少函数参数

问题描述 投票:0回答:1

我正在努力为自己的php应用程序开发自己的错误处理程序,我需要向开发服务器上的用户发送一个漂亮的异常报告。因此,当它捕获到异常时,它必须解析异常堆栈跟踪以显示函数,行参数等。但是,我不再有参数在函数调用中。

我认为这是XDebug引起的,我试图更改xdebug.collect_params的值进行修复,但未成功。实际上,此配置仅更改xdebug默认报告的显示,该报告现在具有函数调用参数。

我制作了一个测试脚本来对其进行测试,以便让您看到。

<?php
$config = 'xdebug.collect_params';
echo "Current value of $config is<br />\n";
var_dump(ini_get($config));

ini_set($config, 3);

function fallDeepToHell($param) {
    echo 'Param is : ' . $param . "<br>\n";
    throw new Exception();
}

try {
    fallDeepToHell('from heaven');
} catch(Exception $e) {
    var_dump($e->getTrace());
    var_dump($e->getTraceAsString());
}
fallDeepToHell('from heaven');

我的开发服务器上的结果是

enter image description here

我正在使用FPM的PHP 7.4。

我的php.ini更改:

max_execution_time = 30
memory_limit = 128M
error_reporting = E_ALL
display_errors = On
display_startup_errors = On
html_errors = On
post_max_size = 100M
upload_max_filesize = 49M
date.timezone = Europe/Paris

;[mail function]
mail.add_x_header = On

;[Session]
session.gc_divisor = 1000
session.gc_maxlifetime = 43200

我的XDebug设置仅与远程操作有关。

php exception xdebug
1个回答
0
投票

我有同样的问题,原来是新的zend.exception_ignore_args INI指令introduced in PHP 7.4

zend.exception_ignore_args是新的INI指令,用于包含或从异常生成的堆栈跟踪中排除参数。

© www.soinside.com 2019 - 2024. All rights reserved.