ホームページ >バックエンド開発 >PHPチュートリアル >PHPでjson_PHPチュートリアルを正しく使用する方法

PHPでjson_PHPチュートリアルを正しく使用する方法

WBOY
WBOYオリジナル
2016-07-21 14:59:23865ブラウズ

バージョン 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 = 'another post';
$obj->id = 21;
$obj-> ;approved = true;
$obj->favorite_count = 1;
$obj->status = NULL;
echo json_encode($obj);

上記のコードの出力は次のとおりです:
コードをコピー コードは次のとおりです:

{
"body":"another post",

"id":21,

「承認済み」:true,

"favorite_count":1,

"status":null
}


jsonはutf-8でエンコードされた文字のみを受け入れるため、json_encode()のパラメータはutf-8でエンコードされている必要があり、そうでない場合はnull文字または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 = 'これは公開です';

private $private_ex = 'これはプライベートです!';

protected $protected_ex = 'これは保護されるべきです';

パブリック関数 getErrorCode() {

return self::ERROR_CODE;

}

}


次に、このクラスのインスタンスで 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)
["e"] => 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

www.bkjia.comtru​​ehttp://www.bkjia.com/PHPjc/328148.html技術記事バージョン 5.2 以降、PHP は json_encode() 関数と json_decode() 関数をネイティブに提供します。前者はエンコードに使用され、後者はデコードに使用されます。 1. json_encode() この関数は主に配列とオブジェクトを変換するために使用されます...
声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。