php.net |  support |  documentation |  report a bug |  advanced search |  search howto |  statistics |  random bug |  login
Bug #26265 zend_parse_parameters() doesn't coerce overloaded objects into strings
Submitted: 2003-11-15 15:03 UTC Modified: 2003-11-28 23:55 UTC
From: adam at trachtenberg dot com Assigned:
Status: Closed Package: Scripting Engine problem
PHP Version: 5CVS-2003-11-15 (dev) OS: *
Private report: No CVE-ID: None
 [2003-11-15 15:03 UTC] adam at trachtenberg dot com
Description:
------------
When passing an object with a __toString() method to a 
function that uses zend_parse_parameters() with an "s" 
value, PHP does not correctly coerce the object into a 
string.

This occurs for both extensions (like SimpleXML) and 
user-defined PHP classes.

Reproduce code:
---------------
class foo {
    function __toString() {
        return "foo";
    }
}

$foo = new foo;
print strrev($foo) ."\n";
print htmlspecialchars($foo) ."\n";

Alternatively:

$xml = '<?xml version="1.0" ?><root><element>text</element></root>';
$s = simplexml_load_string($xml);
print strrev($s->element) ."\n";
print htmlspecialchars($s->element) ."\n";

Expected result:
----------------
oof
foo

Actual result:
--------------
PHP Warning:  htmlspecialchars() expects parameter 1 to 
be string, object given in foo.php on line 10
oof

strrev() uses convert_to_string_ex(), so it works fine. 
htmlspecialchars() uses zend_parse_parms(), so there's a 
warning.

Patches

Add a Patch

Pull Requests

Add a Pull Request

History

AllCommentsChangesGit/SVN commitsRelated reports
 [2003-11-28 23:55 UTC] sniper@php.net
This bug has been fixed in CVS.

In case this was a PHP problem, snapshots of the sources are packaged
every three hours; this change will be in the next snapshot. You can
grab the snapshot at http://snaps.php.net/.
 
In case this was a documentation problem, the fix will show up soon at
http://www.php.net/manual/.

In case this was a PHP.net website problem, the change will show
up on the PHP.net site and on the mirror sites in short time.
 
Thank you for the report, and for helping us make PHP better.


 
PHP Copyright © 2001-2024 The PHP Group
All rights reserved.
Last updated: Mon Apr 29 18:01:30 2024 UTC