http://www.bkjia.com/PHPjc/951493.htmlwww.bkjia.comtruehttp://www.bkjia.com/PHPjc/951493.html技術記事 PHP 言語で JSON を使用する方法 バージョン 5.2 以降、PHP は json_encode() 関数と json_decode() 関数をネイティブに提供し、前者はエンコードに使用され、後者はデコードに使用されます。 1. json_encode() この関数は主に...
バージョン 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}
オブジェクト変換の別の例を見てください:
$obj->body = '別の投稿';
$obj->id = 21;
$obj->approved = true;
$obj->favorite_count = 1;
$obj->status = NULL;
echo json_encode($obj);
結果は
{
"body":"別の投稿",
"id":21,
「承認済み」: true、
「お気に入り数」:1,
「ステータス」: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);
結果は次のとおりです:
[「1」、「2」、「3」]
連想配列に変更する場合:
$arr = Array('1'=>'one', '2'=>'two', '3'=>'three');
echo json_encode($arr);
結果が変わりました:
{"1":"1","2":"2","3":"3"}
データ形式が「[]」(配列)から「{}」(オブジェクト)に変わっていることに注意してください。
「インデックス配列」を「オブジェクト」に強制的に組み込む必要がある場合は、次のように記述できます
json_encode( (object)$arr );
あるいは
json_encode ( $arr, JSON_FORCE_OBJECT );
3. クラス変換
以下は PHP クラスです:
クラス Foo {
const ERROR_CODE = '404';
public $public_ex = 'これは公開です';
private $private_ex = 'これはプライベートです!';
protected $protected_ex = 'これは保護されるべきです';
パブリック関数 getErrorCode() {
自分自身を返す::ERROR_CODE;
}
}
次に、このクラスのインスタンスで json 変換を実行します。
$foo = 新しい Foo;
$foo_json = json_encode($foo);
エコー $foo_json;
出力結果は
{"public_ex":"これは公開です"}
パブリック変数(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 オブジェクトが生成されます:
オブジェクト(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);
結果は連想配列になります:
配列(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