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}
見てください別のオブジェクトでの変換例:$obj->body = 'another post'; $obj->id = 21; $obj->approved = true; $obj->favorite_count = 1; $obj->status = NULL; echo json_encode($obj); 结果为 { "body":"another post", "id":21, "approved":true, "favorite_count":1, "status":null }
json は utf-8 でエンコードされた文字のみを受け入れるため、json_encode() のパラメーターは utf-8 でエンコードされている必要があります。そうしないと、空の文字または null が返されます。中国語で GB2312 エンコードを使用する場合、または外国語で ISO-8859-1 エンコードを使用する場合は、この点に特別な注意を払う必要があります。
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 クラスです:
class Foo { const ERROR_CODE = '404'; public $public_ex = 'this is public'; private $private_ex = 'this is private!'; protected $protected_ex = 'this should be protected'; public function getErrorCode() { return self::ERROR_CODE; } }
Now 、このクラスのインスタンスで json 変換を実行します:
$foo = new Foo; $foo_json = json_encode($foo); echo $foo_json;
出力結果は
{"public_ex":"this is public"} です
パブリック変数 (public) に加えて、他のものも確認できます(定数、プライベート変数、メソッドなど) が失われます。
4. json_decode()
この関数は、json テキストを対応する PHP データ構造に変換するために使用されます。以下に例を示します:
$json = '{"foo": 12345}'; $obj = json_decode($json); print $obj->{'foo'}; // 12345通常、json_decode() は常に配列ではなく PHP オブジェクトを返します。例:
$json = '{"a":1,"b":2,"c":3,"d":4,"e":5}'; var_dump(json_decode($json));結果として、PHP オブジェクトが生成されます:
object(stdClass)#1 (5) { ["a"] => int(1) ["b"] => int(2) ["c"] => int(3) ["d"] => int(4) ["e"] => int(5) }
PHP 連想配列の生成を強制したい場合は、json_decode() にパラメーター true を追加する必要があります:
$json = '{"a":1,"b":2,"c":3,"d":4,"e":5}'; var_dump(json_decode($json,true));
結果は連想配列になります:
array(5) { ["a"] => int(1) ["b"] => int(2) ["c"] => int(3) ["d"] => int(4) ["e"] => int(5) }5. json_decode() よくある間違い
次の 3 つの json の記述方法はすべて間違っています。どこにエラーがあるかわかりますか?
最初のエラーは、JSON 区切り文字では単一引用符ではなく二重引用符の使用のみが許可されていることです。 2 番目の間違いは、JSON の名前と値のペアの「名前」 (コロンの左側の部分) では、いかなる場合でも二重引用符を使用する必要があることです。 3 番目のエラーは、最後の値の後にカンマを追加できないことです。
さらに、json はオブジェクトと配列を表すためにのみ使用できます。json_decode() が文字列または値に対して使用された場合、null が返されます。
var_dump(json_decode("Hello World")) //null