Я ранее задавал тот же вопрос. Я хотел бы расшифровать JSON из: http://pad.skyozora.com/data/pets.json. Ниже приведен код, который я использовал ранее:
<?php
$html=file_get_contents("http://pad.skyozora.com/data/pets.json");
var_dump(json_decode($html,true)); //return null
var_dump(json_last_error()); // return 4
?>
Из последнего ответа, который я знаю, в возвращении json есть UTF8 DOM. Я попытался ответить на аналогичный вопрос: json_decode возвращает NULL после вызова веб-сервиса, но все ответы не работают для меня.
И после дальнейших исследований я нашел способ, который работает:
<?php
$html=file_get_contents("http://pad.skyozora.com/data/pets.json");
$html=preg_replace('/[\x00-\x1F\x80-\xFF]/', '', $html);
var_dump(json_decode($html, true));
var_dump(json_last_error());
?>
Это успешно декодирует JSON в массив. Однако все китайские и японские символьные строки тоже были удалены. Есть идеи?
Отредактировано:
я использовал http://jsonlint.com/ расшифровать JSON из http://pad.skyozora.com/data/pets.json. Здесь останавливаются:
[
161,
"進化的紅面具",
0,
-1,
0,
-1,
1,
1,
10,
50,
1,
0,
0,
0,
0,
[
],
[
0,
0,
0,
0,
0,
0,
0
],
"http:\/\/i.imgur.com\/Y1jZlGW.png",
[
"ウルカヌ火山",
"メジェド
и дай мне ошибку:
Parse error on line 5001:
...山", "メジェド
----------------------^
Expecting 'STRING', 'NUMBER', 'NULL', 'TRUE', 'FALSE', '{', '['
Но я не мог видеть никаких проблем с этой частью JSON.
Код ошибки возврата 4 связан с JSON_ERROR_SYNTAX
Вы должны попытаться исправить свой JSON.
Если вы перейдете по ссылке в браузере, вы можете увидеть это сообщение:
bad character in string literal at line 1 column 294388
Других решений пока нет …