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]

Reply via email to