mirror of
https://github.com/php/php-src.git
synced 2026-04-25 08:58:28 +02:00
MFB: fix #41504 (json_decode() incorrectly decodes JSON arrays with empty string keys).
This commit is contained in:
@@ -357,14 +357,14 @@ static void attach_zval(json_parser *json, int up, int cur, smart_str *key, int
|
||||
{
|
||||
if (!assoc)
|
||||
{
|
||||
add_utf8_property_zval_ex(root, (key->len ? key->c : "_empty_"), (key->len ? (key->len + 1) : sizeof("_empty_")), child TSRMLS_CC);
|
||||
add_utf8_property_zval_ex(root, (key->len ? key->c : ""), (key->len ? (key->len + 1) : sizeof("")), child TSRMLS_CC);
|
||||
#if PHP_MAJOR_VERSION >= 5
|
||||
ZVAL_DELREF(child);
|
||||
#endif
|
||||
}
|
||||
else
|
||||
{
|
||||
add_utf8_assoc_zval_ex(root, (key->len ? key->c : "_empty_"), (key->len ? (key->len + 1) : sizeof("_empty_")), child);
|
||||
add_utf8_assoc_zval_ex(root, (key->len ? key->c : ""), (key->len ? (key->len + 1) : sizeof("")), child);
|
||||
}
|
||||
key->len = 0;
|
||||
}
|
||||
@@ -500,14 +500,14 @@ JSON_parser(zval *z, unsigned short p[], int length, int assoc TSRMLS_DC)
|
||||
|
||||
if (!assoc)
|
||||
{
|
||||
add_utf8_property_zval_ex(JSON(the_zstack)[JSON(the_top)], (key.len ? key.c : "_empty_"), (key.len ? (key.len + 1) : sizeof("_empty_")), mval TSRMLS_CC);
|
||||
add_utf8_property_zval_ex(JSON(the_zstack)[JSON(the_top)], (key.len ? key.c : ""), (key.len ? (key.len + 1) : sizeof("")), mval TSRMLS_CC);
|
||||
#if PHP_MAJOR_VERSION >= 5
|
||||
ZVAL_DELREF(mval);
|
||||
#endif
|
||||
}
|
||||
else
|
||||
{
|
||||
add_utf8_assoc_zval_ex(JSON(the_zstack)[JSON(the_top)], (key.len ? key.c : "_empty_"), (key.len ? (key.len + 1) : sizeof("_empty_")), mval);
|
||||
add_utf8_assoc_zval_ex(JSON(the_zstack)[JSON(the_top)], (key.len ? key.c : ""), (key.len ? (key.len + 1) : sizeof("")), mval);
|
||||
}
|
||||
key.len = 0;
|
||||
buf.len = 0;
|
||||
@@ -631,14 +631,14 @@ JSON_parser(zval *z, unsigned short p[], int length, int assoc TSRMLS_DC)
|
||||
{
|
||||
if (!assoc)
|
||||
{
|
||||
add_utf8_property_zval_ex(JSON(the_zstack)[JSON(the_top)], (key.len ? key.c : "_empty_"), (key.len ? (key.len + 1) : sizeof("_empty_")), mval TSRMLS_CC);
|
||||
add_utf8_property_zval_ex(JSON(the_zstack)[JSON(the_top)], (key.len ? key.c : ""), (key.len ? (key.len + 1) : sizeof("")), mval TSRMLS_CC);
|
||||
#if PHP_MAJOR_VERSION >= 5
|
||||
ZVAL_DELREF(mval);
|
||||
#endif
|
||||
}
|
||||
else
|
||||
{
|
||||
add_utf8_assoc_zval_ex(JSON(the_zstack)[JSON(the_top)], (key.len ? key.c : "_empty_"), (key.len ? (key.len + 1) : sizeof("_empty_")), mval);
|
||||
add_utf8_assoc_zval_ex(JSON(the_zstack)[JSON(the_top)], (key.len ? key.c : ""), (key.len ? (key.len + 1) : sizeof("")), mval);
|
||||
}
|
||||
key.len = 0;
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user