Edit report at https://bugs.php.net/bug.php?id=63004&edit=1

 ID:                 63004
 Comment by:         david at grudl dot com
 Reported by:        juzna dot cz at gmail dot com
 Summary:            errors json_encode do NOT call error handler
 Status:             Not a bug
 Type:               Bug
 Package:            JSON related
 Operating System:   Ubuntu 10.04
 PHP Version:        5.4.6
 Block user comment: N
 Private report:     N

 New Comment:

This is the only one function in whole PHP with this behaviour. So is it a new 
way of error handling or bug?


Previous Comments:
------------------------------------------------------------------------
[2012-09-03 23:36:20] ras...@php.net

json_encode() now checks for valid utf-8. It makes no sense to generate 
warnings 
for core functionality of the function. You can check json_last_error() for 
JSON_ERROR_UTF8 if you want to programmatically catch invalid utf-8.

------------------------------------------------------------------------
[2012-09-03 22:15:55] juzna dot cz at gmail dot com

Actually, a similar bug (52397) has been known for more than 2 years. In latest 
snapshot of PHP 5.4 it just got worse :/

------------------------------------------------------------------------
[2012-09-03 22:14:16] juzna dot cz at gmail dot com

Description:
------------
When there is an error within json_encode (e.g. due to invalid utf8), E_WARNING 
should be raised. However, that doesn't happen in some cases.

It doesn't happen when display_errors is set to On.
In latest snapshot of 5.4 it does not happen at all.

Test script:
---------------
<?php
/**
 * WTF? Error handler is not called, when display_errors=On
 *
 * _errorHandler must be called in each case, but it's not.
 *
 * Results differ on different PHP versions.
 */


function _errorHandler($severity, $message, $file, $line, $context) {
        $GLOBALS['err'] = func_get_args();
//      echo "Error ($severity) $message in $file:$line\n";
}
set_error_handler('_errorHandler');


// display_errors = Off, works fine
{
        ini_set('display_errors', 0);


        // Calls error handler, fine
        $err = NULL;
        $tmp = substr(new stdClass(), 1, 1);
        var_dump($err[0], $err[1]);


        // Calls error handler, fine
        $err = NULL;
        $tmp = json_encode(array("bad utf\xFF"));
        var_dump($err[0], $err[1]);
}



// display_errors = On, WTF???
{
        ini_set('display_errors', 1);


        // Calls error handler, fine
        $err = NULL;
        $tmp = substr(new stdClass(), 1, 1);
        var_dump($err[0], $err[1]);


        // Does NOT call error handler, WTF???
        $err = NULL;
        $tmp = json_encode(array("bad utf\xFF"));
        var_dump($err[0], $err[1]);
}


Expected result:
----------------
int(2)
string(55) "substr() expects parameter 1 to be string, object given"
int(2)
string(49) "json_encode(): Invalid UTF-8 sequence in argument"
int(2)
string(55) "substr() expects parameter 1 to be string, object given"
int(2)
string(49) "json_encode(): Invalid UTF-8 sequence in argument"


Actual result:
--------------
On 5.4.6:

int(2)
string(55) "substr() expects parameter 1 to be string, object given"
int(2)
string(49) "json_encode(): Invalid UTF-8 sequence in argument"
int(2)
string(55) "substr() expects parameter 1 to be string, object given"
NULL
NULL



On 5.4-latest:

int(2)
string(55) "substr() expects parameter 1 to be string, object given"
NULL
NULL
int(2)
string(55) "substr() expects parameter 1 to be string, object given"
NULL
NULL



------------------------------------------------------------------------



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

Reply via email to