PHPでのJSONの使用

WBOY
WBOYオリジナル
2016-06-23 14:30:57673ブラウズ

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 を追加する必要があります:

$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 の書き方は、どれも間違いです。どこにエラーがあるか分かりますか?

$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

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
前の記事:PHPエラー制御次の記事:PHPエラー制御