Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

String appears to be valid JSON, but `json_decode()` returns NULL

Tags:

json

php

I think I've found where the error lies:

    $convertJSON = file_get_contents("http://www.google.com/ig/calculator?hl=en&q=" . $currencyValue . $currencySelectValue . "%3D%3FUSD", true);
    var_dump($convertJSON);
    $convertArr = json_decode($convertJSON, true);
    var_dump($convertArr);

I do that to debug, and I get this result (I entered 555 and Euros):

string(68) "{lhs: "555 Euros",rhs: "796.64700 U.S. dollars",error: "",icc: true}"
NULL

So it seems that the PHP function to decode the JSON object is doing something wrong somewhere. Any help?

like image 948
AKor Avatar asked Jun 13 '11 20:06

AKor


1 Answers

Not a direct response to this question, but an issue I spent a few hours trying to resolve.

If you are attempting to decode JSON that came from a remote file via CURL, and if that file is in UTF-8 format, the beginning of the file may have the following characters (which breaks json_decode():



Which you will not see with the naked eye, only via htmlentities(); I have no idea why they are there, I traced this all the way to curl_exec(), thinking that maybe they were being added there. In any case, those little bastards were being added only when file is in UTF-8 format.

So, assuming you have no control over the encoding of the source file, you can do something like this before passing the string into json_decode():

$encoding = mb_detect_encoding($json);

if($encoding == 'UTF-8') {
  $json = preg_replace('/[^(\x20-\x7F)]*/','', $json);    
}    

print_r(json_decode($json));

I hope I save somebody some time, it took me a few hours of tracing to figure out that's what was happening.

like image 89
Andy Avatar answered Oct 13 '22 16:10

Andy