ID: 37341
User updated by: phpbugs at thequod dot de
Reported By: phpbugs at thequod dot de
Status: Open
Bug Type: Scripting Engine problem
Operating System: Ubuntu Linux
PHP Version: 5CVS-2006-05-06 (CVS)
New Comment:
I just wanted to write a .phpt test case for it and
recognized, that it only happens when using
FastCgiServer /XXX/php5-fcgi-starter -user XXX -group
XXX -pass-header HTTP_AUTHORIZATION -flush -idle-timeout
60
It does NOT happen, if the fcgi binary is running
in "dynamic mode"..
Previous Comments:
------------------------------------------------------------------------
[2006-05-10 22:18:21] phpbugs at thequod dot de
changed summary.. sorry.
------------------------------------------------------------------------
[2006-05-10 22:17:14] phpbugs at thequod dot de
PHP 5.1.5-dev (cgi-fcgi) (built: May 6 2006 22:18:37)
Copyright (c) 1997-2006 The PHP Group
Zend Engine v2.1.0, Copyright (c) 1998-2006 Zend
Technologies
------------------------------------------------------------------------
[2006-05-10 22:16:28] phpbugs at thequod dot de
To reproduce:
--- SERVER.php ---
<?php
# If $_SERVER does not get accessed in this script, it is
nearly empty in the include:
#echo 'Count($_SERVER): '.count($_SERVER)."\n";
require_once('./SERVER.inc.php');
# "Accessing" $_ENV here makes $_SERVER empty in the
include:
$foo = empty($_ENV);
?>
--- SERVER.inc.php ---
<?php
# This will be 2, if $_ENV gets accessed in the main
script, but not $_SERVER!
echo 'Count($_SERVER) (Include): '.count($_SERVER)."\n";
?>
------------------------------------------------------------------------
[2006-05-06 21:27:49] [EMAIL PROTECTED]
Thank you for this bug report. To properly diagnose the problem, we
need a short but complete example script to be able to reproduce
this bug ourselves.
A proper reproducing script starts with <?php and ends with ?>,
is max. 10-20 lines long and does not require any external
resources such as databases, etc.
If possible, make the script source available online and provide
an URL to it here. Try to avoid embedding huge scripts into the report.
------------------------------------------------------------------------
[2006-05-06 20:38:49] phpbugs at thequod dot de
Description:
------------
I've just discovered a nasty bug: in phpMyAdmin's
index.php gets a file required:
require_once('./libraries/common.lib.php');
Inside this file then, $_SERVER is shortened to just two
entries: PHP_SELF and REQUEST_TIME (I've added a
var_dump() at the beginning).
However, var_dump($_SERVER) in index.php before the
include outputs the whole array.
And additionally, now it is correctly filled in the
include's var_dump(): Just accessing $_SERVER (through
var_dump() or $a = $_SERVER) before the include corrects
it inside the include.
Reproduce code:
---------------
I could not reproduce it with a small test script, but with phpMyAdmin
2.8.0.3.
I'm using Apache2 and PHP as FastCGI.
------------------------------------------------------------------------
--
Edit this bug report at http://bugs.php.net/?id=37341&edit=1