编辑已添加。
我从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安装和它的扩展。代码本身没有问题,但我猜它使用了错误安装的一些部分。可以添加更多,但由于我没有找到确切的原因和它的解决方案,但是设法让它再次起作用,我感谢大家指导我做出决议。
答案 0 :(得分:1)
在查看代码时,我认为您没有任何错误。
据说你提到你现在遇到了许多网站的问题。我想知道你是否现在受到恶意机器人的攻击,这可能导致类似于[PHP Bug Report] [1] https://bugs.php.net/bug.php?id=59748上的错误。 [1]:。
我会查看您的日志,看看这些网站上的流量是否已发生变化,以便开始利用此问题。