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 つは「値」(値) のみを格納するインデックス付き配列、もう 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 = 'これはパブリックです';
private $private_ex = 'これはプライベートです! ';
protected $protected_ex = 'これは保護されるべきです';
public function getErrorCode() {
return self::ERROR_CODE;
}
}
次に、このクラスのインスタンスで json 変換を実行します。
$foo = new Foo;
$foo_json = json_encode($foo);
echo $foo_json;
出力結果は
{"public_ex":"this is 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 オブジェクトが生成されます。 (2)
["c"] => int(3)["d"] => int(4)
["e"] => int(5)
}
PHPを強制したい場合連想配列の生成では、json_decode() にパラメーター true を追加する必要があります:
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() のよくあるエラー
$bad_json = "{ 'bar': 'baz' }";
$bad_json = '{ bar: "baz" }';
$bad_json = '{ "bar": "baz", }';
これら 3 つの文字列に対して json_decode() を実行すると、null が返され、エラーが報告されます。
最初の間違いは、json の区切り文字で使用できるのは二重引用符のみであり、一重引用符は使用できないことです。 2 番目の間違いは、JSON の名前と値のペアの「名前」 (コロンの左側の部分) では、いかなる場合でも二重引用符を使用する必要があることです。 3 番目のエラーは、最後の値の後にカンマを追加できないことです。
さらに、json はオブジェクトと配列を表すためにのみ使用できます。json_decode() を文字列または値に使用すると、null が返されます。
var_dump(json_decode("Hello World")); //null