ID: 8315
Updated by: cynic
Reported By: [EMAIL PROTECTED]
Old-Status: Open
Status: Bogus
Bug Type: *Session related
PHP Version: 4.0 Latest CVS (18/12/2000)
Assigned To:
Comments:
Previous Comments:
---------------------------------------------------------------------------
[2000-12-18 13:02:23] [EMAIL PROTECTED]
Apache 1.3.14 through apache-1.3_20001218111201
PHP snapshots since about two weeks ago through php-4.0.4RC6
stock php.ini-optiomized (with the exception of error_reporting E_ALL)
Actually I cannot confirm this bug with latest CVS, because it won't build, but this
has been valid for apachephp4.dll for about two weeks.
This issue can be stripped down to: it seems that with register_globals off, variables
registered in a session become members of $HTTP_SESSION_VARS on the NEXT request, and
when unregistered, get re-registered on the next request. The latter looks like an
outstanding bug.
The (lack of) presence of the error_reporting() calls in the beginning of all the
files has no effect on the issue.
Also, notice that when register_globals is on, session_is_registered() returns true,
the global variable has it's value and is subsequently recreated on the next request,
however, on the request where the session is started, $HTTP_SESSION_VARS is empty.
With register_globals off, it already contains the variable when I traverse the array.
(with the following bump: the increment call in the following block:
$count = 0 ;
session_register( 'count' ) ;
$HTTP_SESSION_VARS['count']++ ;
results in "undefined index" warning...)
Seems like session support should be tagged 'experimental' on win32 Apache... Which is
a pitty, as this httpd represents the shortest and most straightforward way from win32
dev machines to most unix servers...
register_globals on
=======================================================
test1.php
=======================================================
error_reporting( E_ALL ) ;
session_start() ;
$count = 0 ;
session_register( 'count' ) ;
$count++ ;
echo session_is_registered('count') ? 'yes' : 'no' ;
echo $count ;
foreach( $HTTP_SESSION_VARS as $k => $v ) {
echo "$k : $vn" ;
} ;
echo '<a href="/test2.php">test2.php</a>'
=======================================================
relevant output:
=======================================================
yes
1
=======================================================
test2.php
=======================================================
error_reporting( E_ALL ) ;
session_start() ;
session_unregister( 'count' ) ;
$count++ ;
echo session_is_registered('count') ? 'yes' : 'no' ;
echo $count ;
foreach( $HTTP_SESSION_VARS as $k => $v ) {
echo "$k : $vn" ;
} ;
echo '<a href="/test3.php">test3.php</a>' ;
=======================================================
relevant output:
=======================================================
no
2
count : 1
test3.php
=======================================================
error_reporting( E_ALL ) ;
session_start() ;
echo session_is_registered('count') ? 'yes' : 'no' ;
echo $count ;
foreach( $HTTP_SESSION_VARS as $k => $v ) {
echo "$k : $vn" ;
} ;
echo '<a href="test1.php">test1.php</a>' ;
=======================================================
relevant output:
=======================================================
no
Warning: Undefined variable: count ...
register_globals off
=======================================================
test1.php
=======================================================
error_reporting( E_ALL ) ;
session_start() ;
$count = 0 ;
session_register( 'count' ) ;
$HTTP_SESSION_VARS['count']++ ;
echo session_is_registered('count') ? 'yes' : 'no' ;
echo $HTTP_SESSION_VARS['count'] ;
foreach( $HTTP_SESSION_VARS as $k => $v ) {
echo "$k : $vn" ;
} ;
echo '<a href="/test2.php">test2.php</a>'
=======================================================
relevant output:
=======================================================
Warning: Undefined index: count ...
yes
1
count : 1
=======================================================
test2.php
=======================================================
error_reporting( E_ALL ) ;
session_start() ;
session_unregister( 'count' ) ;
$HTTP_SESSION_VARS['count']++ ;
echo session_is_registered('count') ? 'yes' : 'no' ;
echo $HTTP_SESSION_VARS['count'] ;
foreach( $HTTP_SESSION_VARS as $k => $v ) {
echo "$k : $vn" ;
} ;
echo '<a href="/test3.php">test3.php</a>' ;
=======================================================
relevant output:
=======================================================
no
2
count : 2
test3.php
=======================================================
error_reporting( E_ALL ) ;
session_start() ;
echo session_is_registered('count') ? 'yes' : 'no' ;
echo $HTTP_SESSION_VARS['count'] ;
foreach( $HTTP_SESSION_VARS as $k => $v ) {
echo "$k : $vn" ;
} ;
echo '<a href="test1.php">test1.php</a>' ;
=======================================================
relevant output:
=======================================================
yes
2
count : 2
---------------------------------------------------------------------------
ATTENTION! Do NOT reply to this email!
To reply, use the web interface found at http://bugs.php.net/?id=8315&edit=2
--
PHP Development Mailing List <http://www.php.net/>
To unsubscribe, e-mail: [EMAIL PROTECTED]
For additional commands, e-mail: [EMAIL PROTECTED]
To contact the list administrators, e-mail: [EMAIL PROTECTED]