1. ホーム
  2. php

[解決済み] PHP の json_decode() は、有効な JSON で NULL を返しますか?

2022-01-28 01:04:12

質問

このJSONオブジェクトをプレーンテキストファイル上に保存しています。

{
    "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"
    }
}

でデコードしようとすると json_decode() の場合、NULLを返します。なぜでしょうか? ファイルは読めます。 file_get_contents() で、うまくいきました)。

に対してJSONをテストしてみました。 http://jsonlint.com/ で、完全に有効です。

ここで何が問題なのか?

更新(2010年問題への有効な対応)

Googleで答えを探していたら、SOに戻りました。 ウェブサービス呼び出し後、json_decode が NULL を返す . 私のJSONファイルには、UTF BOMシーケンス(あるはずのないバイナリ文字)があり、そのためJSON構造が壊れていました。Hex Editorで、そのバイトを消しました。すべてが正常に戻りました。 なぜこのようなことが起こったのでしょうか? Microsoft Windowsのメモ帳で編集したため。 恐るべし!

解決方法は?

特殊文字のエンコーディングが原因かもしれません。次のような質問をすることができます。 json_last_error() をクリックすると、確実な情報を得ることができます。

<ブロッククオート

更新: 問題は解決されました。