161 votes

PHP json_decode() retourne NULL avec un JSON apparemment valide ?

Cet objet JSON est stocké dans un fichier texte :

{
    "MySQL": {
        "Server": "(server)",
        "Username": "(user)",
        "Password": "(pwd)",
        "DatabaseName": "(dbname)"
    },
    "Ftp": {
        "Server": "(server)",
        "Username": "(user)",
        "Password": "(pwd)",
        "RootFolder": "(rf)"
    },
    "BasePath": "../../bin/",
    "NotesAppPath": "notas",
    "SearchAppPath": "buscar",
    "BaseUrl": "http:\/\/montemaiztusitio.com.ar",
    "InitialExtensions": [
        "nem.mysqlhandler",
        "nem.string",
        "nem.colour",
        "nem.filesystem",
        "nem.rss",
        "nem.date",
        "nem.template",
        "nem.media",
        "nem.measuring",
        "nem.weather",
        "nem.currency"
    ],
    "MediaPath": "media",
    "MediaGalleriesTable": "journal_media_galleries",
    "MediaTable": "journal_media",
    "Journal": {
        "AllowedAdFileFormats": [
            "flv:1",
            "jpg:2",
            "gif:3",
            "png:4",
            "swf:5"
        ],
        "AdColumnId": "3",
        "RSSLinkFormat": "%DOMAIN%\/notas\/%YEAR%-%MONTH%-%DAY%\/%TITLE%/",
        "FrontendLayout": "Flat",
        "AdPath": "ad",
        "SiteTitle": "Monte Maíz: Tu Sitio",
        "GlobalSiteDescription": "Periódico local de Monte Maíz.",
        "MoreInfoAt": "Más información aquí, en el Periódico local de Monte Maíz.",
        "TemplatePath": "templates",
        "WeatherSource": "accuweather:SAM|AR|AR005|MONTE MAIZ",
        "WeatherMeasureType": "1",
        "CurrencySource": "cotizacion-monedas:Dolar|Euro|Real",
        "TimesSingular": "vez",
        "TimesPlural": "veces"
    }
}

Lorsque j'essaie de le décoder avec json_decode() il renvoie NULL. Pourquoi ? Le fichier est lisible (j'ai essayé de faire un écho à file_get_contents() et cela a fonctionné correctement).

J'ai testé JSON contre http://jsonlint.com/ et c'est tout à fait valable.

Qu'est-ce qui ne va pas ?

2voto

Muhammad Ichsan Points 69

Cela se produit parce que vous utilisez (') au lieu de {") dans votre valeur ou votre clé.

Voici un format erroné.

{'name':'ichsan'}

Ces éléments seront renvoyés à NULL si vous les décodez.

Vous devez transmettre la requête json comme suit.

{"name":"ichsan"}

1voto

Destreyf Points 66

Comme indiqué par Jürgen Math, l'utilisation de la méthode preg_replace listée par user2254008 a également résolu le problème pour moi.

Ce n'est pas limité à Chrome, il semble que ce soit un problème de conversion de jeu de caractères (au moins dans mon cas, Unicode -> UTF8).

En tant que futur nœud, l'objet JSON que je décodais provenait de json.dumps de Python

1voto

TomoMiha Points 31

I

mysqli_set_charset($con, "utf8");

a

1voto

J

if(get_magic_quotes_gpc()){
   $param = stripslashes($row['your column name']);
}else{
  $param = $row['your column name'];
}

$param = json_decode(html_entity_decode($param),true);
$json_errors = array(
JSON_ERROR_NONE => 'No error has occurred',
JSON_ERROR_DEPTH => 'The maximum stack depth has been exceeded',
JSON_ERROR_CTRL_CHAR => 'Control character error, possibly incorrectly encoded',
JSON_ERROR_SYNTAX => 'Syntax error',
);
echo 'Last error : ', $json_errors[json_last_error()], PHP_EOL, PHP_EOL;
print_r($param);

1voto

Vous trouverez ici une petite enveloppe JSON avec des actions correctives qui traitent les problèmes de nomenclature et de non-ASCI : https://stackoverflow.com/a/43694325/2254935

Prograide.com

Prograide est une communauté de développeurs qui cherche à élargir la connaissance de la programmation au-delà de l'anglais.
Pour cela nous avons les plus grands doutes résolus en français et vous pouvez aussi poser vos propres questions ou résoudre celles des autres.

Powered by:

X