Bug #61766 [Fbk-Opn]: call_user_func sends scrambled class name to autoload

2012-04-19 Thread admin dot windows at gmail dot com
Edit report at https://bugs.php.net/bug.php?id=61766edit=1

 ID: 61766
 User updated by:admin dot windows at gmail dot com
 Reported by:admin dot windows at gmail dot com
 Summary:call_user_func sends scrambled class name to
 autoload
-Status: Feedback
+Status: Open
 Type:   Bug
 Package:*General Issues
 Operating System:   ALL
 PHP Version:5.3.10
 Block user comment: N
 Private report: N

 New Comment:

Hi,
I have following extensions enabled on my hosting (Rackspace):

Core, date, ereg, libxml, openssl, pcre, sqlite3, zlib, bz2, calendar, ctype, 
hash, filter, ftp, gettext, gmp, SPL, iconv, Reflection, session, standard, 
shmop, SimpleXML, sockets, exif, tokenizer, xml, apache2handler, bcmath, curl, 
dba, dom, fileinfo, gd, imagick, imap, intl, json, ldap, pdf, mbstring, mcrypt, 
memcache, mongo, mssql, mysql, mysqli, odbc, PDO, pdo_dblib, pdo_mysql, 
PDO_ODBC, pdo_pgsql, pdo_sqlite, pgsql, Phar, posix, pspell, recode, redis, 
snmp, soap, sysvmsg, sysvsem, sysvshm, tidy, uploadprogress, wddx, xmlreader, 
xmlrpc, xmlwriter, xsl, yaz, zip, ionCube Loader, Zend Guard Loader, XCache


Previous Comments:

[2012-04-19 07:07:33] ahar...@php.net

I can't reproduce this.

What extensions do you have enabled?


[2012-04-18 15:19:23] admin dot windows at gmail dot com

Description:

I have discovered weird behaviour of call_user_func that breaks class 
autoloader by providing scrambled class name for example instead of myObject 
it provides zw87zl18.
This event only occurs if you are using custom class autoloader and requesting 
static method that is not declared as static.

Test script:
---
//FILE: myObject.php
class myObject {
public static function method1(){var_dump(__METHOD__);}
public function method2(){var_dump(__METHOD__);}
}

//FILE: index.php
ini_set('display_errors', TRUE);

function __autoload($className) {
   include sprintf('%s/%s.php', getcwd(), $className);
}

call_user_func(array('myObject', 'method1'));//works fine

call_user_func(array('myObject', 'method2'));//produce an error

Expected result:

string(17) myObject::method1
string(17) myObject::method2

Actual result:
--
string(17) myObject::method1
Warning: include(/www/zw87zl18.php) [function.include]: failed to open stream: 
No such file or directory in /www/index.php on line 9

Warning: include() [function.include]: Failed opening '/www/zw87zl18.php' for 
inclusion (include_path='.:/usr/share/pear:/usr/share/php') in /www/index.php 
on line 9

Warning: include(/www/zw87zl18.php) [function.include]: failed to open stream: 
No such file or directory in /www/index.php on line 9

Warning: include() [function.include]: Failed opening '/www/zw87zl18.php' for 
inclusion (include_path='.:/usr/share/pear:/usr/share/php') in /www/index.php 
on line 9
string(17) myObject::method2 






-- 
Edit this bug report at https://bugs.php.net/bug.php?id=61766edit=1


Bug #61766 [Fbk-Opn]: call_user_func sends scrambled class name to autoload

2012-04-19 Thread admin dot windows at gmail dot com
Edit report at https://bugs.php.net/bug.php?id=61766edit=1

 ID: 61766
 User updated by:admin dot windows at gmail dot com
 Reported by:admin dot windows at gmail dot com
 Summary:call_user_func sends scrambled class name to
 autoload
-Status: Feedback
+Status: Open
 Type:   Bug
 Package:*General Issues
 Operating System:   ALL
 PHP Version:5.3.10
 Block user comment: N
 Private report: N

 New Comment:

Unfortunately I don't have rights to enable or disable modules on my cloud, I 
would pass this issue to my hosting support.
Also I noticed that server is protected with the Suhosin Patch 0.9.10 can it 
cause 
this behavior?


Previous Comments:

[2012-04-19 09:21:26] johan...@php.net

Please disable ionCube Loader, Zend Guard Loader and XCache as all of these 3rd 
party modules change the engine's behaviour.


[2012-04-19 09:06:56] admin dot windows at gmail dot com

Hi,
I have following extensions enabled on my hosting (Rackspace):

Core, date, ereg, libxml, openssl, pcre, sqlite3, zlib, bz2, calendar, ctype, 
hash, filter, ftp, gettext, gmp, SPL, iconv, Reflection, session, standard, 
shmop, SimpleXML, sockets, exif, tokenizer, xml, apache2handler, bcmath, curl, 
dba, dom, fileinfo, gd, imagick, imap, intl, json, ldap, pdf, mbstring, mcrypt, 
memcache, mongo, mssql, mysql, mysqli, odbc, PDO, pdo_dblib, pdo_mysql, 
PDO_ODBC, pdo_pgsql, pdo_sqlite, pgsql, Phar, posix, pspell, recode, redis, 
snmp, soap, sysvmsg, sysvsem, sysvshm, tidy, uploadprogress, wddx, xmlreader, 
xmlrpc, xmlwriter, xsl, yaz, zip, ionCube Loader, Zend Guard Loader, XCache


[2012-04-19 07:07:33] ahar...@php.net

I can't reproduce this.

What extensions do you have enabled?


[2012-04-18 15:19:23] admin dot windows at gmail dot com

Description:

I have discovered weird behaviour of call_user_func that breaks class 
autoloader by providing scrambled class name for example instead of myObject 
it provides zw87zl18.
This event only occurs if you are using custom class autoloader and requesting 
static method that is not declared as static.

Test script:
---
//FILE: myObject.php
class myObject {
public static function method1(){var_dump(__METHOD__);}
public function method2(){var_dump(__METHOD__);}
}

//FILE: index.php
ini_set('display_errors', TRUE);

function __autoload($className) {
   include sprintf('%s/%s.php', getcwd(), $className);
}

call_user_func(array('myObject', 'method1'));//works fine

call_user_func(array('myObject', 'method2'));//produce an error

Expected result:

string(17) myObject::method1
string(17) myObject::method2

Actual result:
--
string(17) myObject::method1
Warning: include(/www/zw87zl18.php) [function.include]: failed to open stream: 
No such file or directory in /www/index.php on line 9

Warning: include() [function.include]: Failed opening '/www/zw87zl18.php' for 
inclusion (include_path='.:/usr/share/pear:/usr/share/php') in /www/index.php 
on line 9

Warning: include(/www/zw87zl18.php) [function.include]: failed to open stream: 
No such file or directory in /www/index.php on line 9

Warning: include() [function.include]: Failed opening '/www/zw87zl18.php' for 
inclusion (include_path='.:/usr/share/pear:/usr/share/php') in /www/index.php 
on line 9
string(17) myObject::method2 






-- 
Edit this bug report at https://bugs.php.net/bug.php?id=61766edit=1