JSON_ERROR_RECURSION对json_encode的意义是什么?

时间:2016-05-26 09:30:55

标签: php php-7

由于某些奇怪的原因,我在PHP7上每100个请求都会收到此错误,我无法摆脱它,直到我重新启动fpm恶魔,然而,真正的问题是我无法解释错误是什么开始诊断这个。< / p>

我看了一下文档http://php.net/manual/en/function.json-last-error.php,它不是很有用,似乎没有任何真正的链接。

我知道这个错误实际上并不与递归深度(JSON_ERROR_DEPTH)有关,那么这个错误究竟意味着什么呢?

这是失败的数组的var_dump()

 array (
'ns' => 'user',
'where' => '{"_id":"MongoDB\\\\BSON\\\\ObjectID(5505a4f647ac1824618b4567)","status":10}',
'projection' =>
array (
),
'sort' =>
array (
),
'limit' => NULL,
'skip' => NULL,
)

2 个答案:

答案 0 :(得分:4)

JSON_ERROR_RECURSION表示传递给json_encode()的数据包含一个或多个递归引用。

$data = array();
$data['foo'] = &$data; // <-- recursive reference here

var_dump(json_encode($data)); // bool(false)
var_dump(json_last_error_msg()); // string(18) "Recursion detected"
var_dump(json_last_error() === JSON_ERROR_RECURSION); // bool(true)

这样的代码可以工作:

$data['foo'] = 'hello';
$data['bar'] = &$data['foo'];

但不喜欢这个(另一个递归引用):

$data['foo'] = [1, 2, 3];
$data['foo'][] = &$data['foo'];

递归引用意味着引用指向一个变量,而该变量又包含相同的引用。

答案 1 :(得分:0)

最有可能需要更新mongodb驱动程序(或者可能是其他扩展程序)。带bug的扩展可能会写入共享内存(不可变数组) - 不允许这样做。

可以使用opcache.protect_memoryhttp://php.net/manual/en/opcache.configuration.php#ini.opcache.protect-memory

检测到它

http://news.php.net/php.internals/98210