PHP代码生成分段错误

时间:2013-05-02 13:30:52

标签: php segmentation-fault

编辑已添加。

我从PHP三元操作中得到了一个分段错误。我正在使用PHP(5.4.13)。

<?php

$t = empty($_GET['t2']) ? $_GET['t2'] : 'test';
$t = empty($_GET['t2']) ? 'test' : $_GET['t2'];

echo '<pre>'.print_r($t, true).'</pre>';

?>

陈述:

$t = empty($_GET['t2']) ? $_GET['t2'] : 'test';
$t = empty($_GET['t2']) ? 'test' : $_GET['t2'];

调度分段错误(我检查了apache错误日志)。上面评论的陈述不会引发分段错误。

我怀疑这是唯一的源错误,但这是我能够缩小的范围。几乎所有使用这个php的网站现在都有这个问题。

我不认为这是一个错误!更多php安装或其中一个依赖项中的错误。但由于没有function被使用,只有语言功能,我认为它可以很容易地缩小。

修改 我想知道导致分段错误的常见问题是什么,如果可以从上面的代码中识别出其中一个问题,那么我将知道在哪里寻找解决方案以及如何采取行动。 (对于那些对此感到疑惑的人来说,这是个问题)

编辑2: 现在准备就绪,$ _GET中没有更多的作业,所以现在我猜它是advisable并且有效。但错误仍然存​​在。

编辑3: 对于valgrind,跟踪是:

==3775== Process terminating with default action of signal 11 (SIGSEGV)
==3775==  Bad permissions for mapped region at address 0x0
==3775==    at 0x0: ???
==3775==    by 0xF60F9F7: execute (in /opt/rh/php54/root/usr/lib64/httpd/modules/libphp5.so)
==3775==    by 0xF5A619F: zend_execute_scripts (in /opt/rh/php54/root/usr/lib64/httpd/modules/libphp5.so)
==3775==    by 0xF548E87: php_execute_script (in /opt/rh/php54/root/usr/lib64/httpd/modules/libphp5.so)
==3775==    by 0xF650A94: ??? (in /opt/rh/php54/root/usr/lib64/httpd/modules/libphp5.so)
==3775==    by 0x133BAF: ap_run_handler (in /usr/sbin/httpd)
==3775==    by 0x13746D: ap_invoke_handler (in /usr/sbin/httpd)
==3775==    by 0x142B2F: ap_process_request (in /usr/sbin/httpd)
==3775==    by 0x13F9A7: ??? (in /usr/sbin/httpd)
==3775==    by 0x13B6B7: ap_run_process_connection (in /usr/sbin/httpd)
==3775==    by 0x147976: ??? (in /usr/sbin/httpd)
==3775==    by 0x147C45: ??? (in /usr/sbin/httpd)

和gdb是:

#0  0x0000000000000000 in ?? ()
#1  0x00007fc4dd8a49f8 in execute () from /etc/httpd/modules/libphp54-php5.so
#2  0x00007fc4dd83b1a0 in zend_execute_scripts () from /etc/httpd/modules/libphp54-php5.so
#3  0x00007fc4dd7dde88 in php_execute_script () from /etc/httpd/modules/libphp54-php5.so
#4  0x00007fc4dd8e5a95 in ?? () from /etc/httpd/modules/libphp54-php5.so
#5  0x00007fc4e818dbb0 in ap_run_handler ()
#6  0x00007fc4e819146e in ap_invoke_handler ()
#7  0x00007fc4e819cb30 in ap_process_request ()
#8  0x00007fc4e81999a8 in ?? ()
#9  0x00007fc4e81956b8 in ap_run_process_connection ()
#10 0x00007fc4e81a1977 in ?? ()
#11 0x00007fc4e81a1c46 in ?? ()
#12 0x00007fc4e81a2293 in ap_mpm_run ()
#13 0x00007fc4e8179900 in main ()

最终修改

正如我从一开始就怀疑它肯定是来自一个损坏的php安装和它的扩展。代码本身没有问题,但我猜它使用了错误安装的一些部分。可以添加更多,但由于我没有找到确切的原因和它的解决方案,但是设法让它再次起作用,我感谢大家指导我做出决议。

1 个答案:

答案 0 :(得分:1)

在查看代码时,我认为您没有任何错误。

据说你提到你现在遇到了许多网站的问题。我想知道你是否现在受到恶意机器人的攻击,这可能导致类似于[PHP Bug Report] [1] https://bugs.php.net/bug.php?id=59748上的错误。 [1]:。

我会查看您的日志,看看这些网站上的流量是否已发生变化,以便开始利用此问题。