バージョン 5.2 以降、PHP は json_encode() 関数と json_decode() 関数をネイティブに提供し、前者はエンコードに使用され、後者はデコードに使用されます。
1. json_encode()
この関数は主に配列とオブジェクトを json 形式に変換するために使用されます。まず配列変換の例を見てみましょう:
$arr = array ('a'=>1,'b'=>2,'c'=>3,'d'=>4,'e '= >5);
echo json_encode($arr);
上記のコードの出力結果は次のとおりです:
{"a":1,"b":2,"c":3,"d":4,"e":5}
オブジェクト変換の別の例を見てください:
"id":21,
「承認済み」:true,
"favorite_count":1,
"status":null
}
2. インデックス付き配列と連想配列
PHP は 2 種類の配列をサポートしています。1 つは「値」(value) のみを保存するインデックス付き配列、もう 1 つは保存される「名前と値のペア」です。連想配列。
JavaScript は連想配列をサポートしていないため、json_encode() はインデックス付き配列のみを配列形式に変換し、連想配列をオブジェクト形式に変換します。
たとえば、今はインデックス付き配列があります:
$arr = Array('one', 'two', 'three');
echo json_encode($arr);
出力結果は次のとおりです:
["one","two","three"]
連想配列に変更する場合:
$arr = Array('1'=>'one', '2'=>'two', '3'=>'three');
echo json_encode ($arr);
結果は変わります:
{"1":"one","2":"two","3":"three"}
データ形式が「[]」(配列)から「{}」(オブジェクト)に変更されていることに注意してください。
「インデックス配列」を「オブジェクト」に強制的に入れる必要がある場合は、次のように書くことができます
json_encode( (object)$arr );
または:
json_encode ( $arr, JSON_FORCE_OBJECT );
3. クラス変換
以下は PHP クラスです:
const ERROR_CODE = '404';
public $public_ex = 'これは公開です';
private $private_ex = 'これはプライベートです!';
protected $protected_ex = 'これは保護されるべきです';
パブリック関数 getErrorCode() {return self::ERROR_CODE;
}
}
4. json_decode()
この関数は、json テキストを対応する PHP データ構造に変換するために使用されます。以下に例を示します:
PHP 連想配列の生成を強制したい場合は、json_decode() にパラメーター true を追加する必要があります:
$json = '{"a":1,"b":2,"c":3,"d" :4," e":5}';
var_dump(json_decode($json),true);
結果は連想配列になります:
最初の間違いは、JSON の区切り文字では単一引用符ではなく二重引用符の使用のみが許可されていることです。 2 番目の間違いは、JSON の名前と値のペアの「名前」 (コロンの左側の部分) では、いかなる場合でも二重引用符を使用する必要があることです。 3 番目のエラーは、最後の値の後にカンマを追加できないことです。
さらに、json はオブジェクトと配列を表すためにのみ使用できます。json_decode() が文字列または値に対して使用された場合、null が返されます。
var_dump(json_decode("Hello World")); //null