节点 12 现在使用格式良好的 JSON.stringify,它为单独的代理输出转义序列。当有一个单独的代理被转义时,PHP 无法对此进行 json_decode。
以 Node.js 中的以下代码示例为例。
var a = ' ';
JSON.stringify(a.slice(0, 15));
// Node 10 output:
'"�"';
// Node 12 output:
'"\\ud835"'
然后,此响应以 JSON 格式发送到 PHP 服务器并进行解码。这是发生错误的地方。Node10 的输出过去可以与 PHP json_decode 一起正常工作,但它不再适用于 Node12 的输出。
我简化了 NODE->PHP 示例,见下文。
<?php
$string = '{"string": "\\ud835"}';
var_dump(json_decode($string, false, 512, JSON_THROW_ON_ERROR | JSON_INVALID_UTF8_IGNORE | JSON_INVALID_UTF8_SUBSTITUTE));
// Output:
Fatal error: Uncaught JsonException: Single unpaired UTF-16 surrogate in unicode escape in phptest.php:36
Stack trace:
#0 phptest.php(36): json_decode('{"string": "\xF0\x9D\x98...', false, 512, 7340032)
#1 {main}
thrown in phptest.php on line 36
我希望以下选项JSON_INVALID_UTF8_IGNORE
或JSON_INVALID_UTF8_SUBSTITUTE
在 PHP 7.3+ 中与 json_decode 一起使用,但它根本没有帮助。JSON_THROW_ON_ERROR
实际上会引发错误以使其更易于调试。