PHPを使用したJSON

この章では、PHPプログラミング言語を使用してJSONオブジェクトをエンコードおよびデコードする方法について説明します。まず、PHP forJSONを使用してプログラミングを開始するための環境の準備から始めましょう。

環境

PHP 5.2.0以降、JSON拡張機能はデフォルトでPHPにバンドルされ、コンパイルされています。

JSON関数

関数 ライブラリ
json_encode 値のJSON表現を返します。
json_decode JSON文字列をデコードします。
json_last_error 最後に発生したエラーを返します。

PHPでのJSONのエンコード(json_encode)

PHP json_encode()関数は、PHPでJSONをエンコードするために使用されます。この関数は、成功した場合は値のJSON表現を返し、失敗した場合はFALSEを返します。

構文

string json_encode ( $value [, $options = 0 ] )

パラメーター

  • value−エンコードされている値。この関数は、UTF-8でエンコードされたデータでのみ機能します。

  • options −このオプションの値は、JSON_HEX_QUOT、JSON_HEX_TAG、JSON_HEX_AMP、JSON_HEX_APOS、JSON_NUMERIC_CHECK、JSON_PRETTY_PRINT、JSON_UNESCAPED_SLASHES、JSON_FORCE_OBJECTで構成されるビットマスクです。

次の例は、PHPを使用して配列をJSONに変換する方法を示しています。

<?php
   $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}

次の例は、PHPオブジェクトをJSONに変換する方法を示しています-

<?php
   class Emp {
      public $name = "";
      public $hobbies  = "";
      public $birthdate = "";
   }
	
   $e = new Emp();
   $e->name = "sachin";
   $e->hobbies  = "sports";
   $e->birthdate = date('m/d/Y h:i:s a', "8/5/1974 12:20:03 p");
   $e->birthdate = date('m/d/Y h:i:s a', strtotime("8/5/1974 12:20:03"));

   echo json_encode($e);
?>

実行中、これは次の結果を生成します-

{"name":"sachin","hobbies":"sports","birthdate":"08\/05\/1974 12:20:03 pm"}

PHPでのJSONのデコード(json_decode)

PHP json_decode()関数は、PHPでJSONをデコードするために使用されます。この関数は、jsonから適切なPHPタイプにデコードされた値を返します。

構文

mixed json_decode ($json [,$assoc = false [, $depth = 512 [, $options = 0 ]]])

パラメータ

  • json_string −これはエンコードされた文字列であり、UTF-8でエンコードされたデータである必要があります。

  • assoc −これはブール型のパラメーターです。TRUEに設定すると、返されるオブジェクトは連想配列に変換されます。

  • depth −再帰の深さを指定する整数型パラメータです

  • options −これはJSONデコードの整数型ビットマスクであり、JSON_BIGINT_AS_STRINGがサポートされています。

次の例は、PHPを使用してJSONオブジェクトをデコードする方法を示しています-

<?php
   $json = '{"a":1,"b":2,"c":3,"d":4,"e":5}';

   var_dump(json_decode($json));
   var_dump(json_decode($json, true));
?>

実行中、次の結果が生成されます-

object(stdClass)#1 (5) {
   ["a"] => int(1)
   ["b"] => int(2)
   ["c"] => int(3)
   ["d"] => int(4)
   ["e"] => int(5)
}

array(5) {
   ["a"] => int(1)
   ["b"] => int(2)
   ["c"] => int(3)
   ["d"] => int(4)
   ["e"] => int(5)
}