ホームページ > バックエンド開発 > PHPチュートリアル > PHP での JSON の使用と変換、phpJSON の使用と変換_PHP チュートリアル

PHP での JSON の使用と変換、phpJSON の使用と変換_PHP チュートリアル

WBOY
リリース: 2016-07-13 10:09:39
オリジナル
1222 人が閲覧しました

phpでのJSONの使用と変換、phpJSONの使用と変換

以前、php で json データを返す簡単な例を書いたことがありますが、ちょうどオンラインで json を紹介した記事を見つけました。これも非常に詳細で参考になります。内容は以下の通りです

バージョン 5.2 以降、PHP は json_encode() 関数と json_decode() 関数をネイティブに提供し、前者はエンコードに使用され、後者はデコードに使用されます。

1. json_encode()

コードをコピーします コードは次のとおりです:

$arr = 配列 ('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->承認済み = true;
$obj->お気に入り数 = 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('1', 'two', 'three');
echo json_encode($arr);

出力

コードをコピーします コードは次のとおりです:

[「1」、「2」、「3」]

連想配列に変更する場合:

コードをコピーします コードは次のとおりです:

$arr = Array('1'=>'1', '2'=>'two', '3'=>'three');
echo json_encode($arr);

出力は次のようになります

コードをコピーします コードは次のとおりです:

{"1":"1"、"2":"2"、"3":"3"}

データ形式が「[]」(配列)から「{}」(オブジェクト)に変更されていることに注意してください。

「インデックス配列」を「オブジェクト」に強制的に入れる必要がある場合は、次のように書くことができます

コードをコピーします コードは次のとおりです:

json_encode( (オブジェクト)$arr );

または

コードをコピーします コードは次のとおりです:

json_encode ( $arr, JSON_FORCE_OBJECT );

3. クラス変換

以下は PHP クラスです:

コードをコピーします コードは次のとおりです:

クラス Foo {
const ERROR_CODE = '404';
public $public_ex = 'これはパブリックです';
private $private_ex = 'これはプライベートです!';
protected $protected_ex = 'これは保護されるべきです';
パブリック関数 getErrorCode() {
return self::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 = '{ "バー": "バズ", }';

これら 3 つの文字列に対して json_decode() を実行すると、null が返され、エラーが報告されます。

最初のエラーは、JSON 区切り文字 (区切り文字) では単一引用符ではなく二重引用符の使用のみが許可されていることです。 2 番目の間違いは、JSON の名前と値のペアの「名前」 (コロンの左側の部分) では、いかなる場合でも二重引用符を使用する必要があることです。 3 番目のエラーは、最後の値の後にカンマを追加できないことです。

さらに、json はオブジェクトと配列を表すためにのみ使用できます。json_decode() が文字列または値に対して使用された場合、null が返されます。

コードをコピーします コードは次のとおりです:
var_dump(json_decode("Hello World")); //null

以上がこの記事の全内容です。読んで皆さんに何かを得ていただければ幸いです。

http://www.bkjia.com/PHPjc/942983.html

tru​​ehttp://www.bkjia.com/PHPjc/942983.html技術記事 php での JSON の使用と変換、phpJSON の使用と変換。以前、php から json データを返す簡単な例を書きました。ちょうどオンラインで、json についても紹介されている記事を見つけました。 .
関連ラベル:
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート