php json 形式変換方法: 1. json_encode 関数を使用して、php 配列とオブジェクトを json 形式に変換します; 2. json_decode 関数を使用して、json テキストを対応する PHP データ構造に変換します。
この記事の動作環境: Windows 7 システム、PHP バージョン 7.1、DELL G3 コンピューター。
php json 形式変換
php は、json_encode($str) と json_decode($str) をネイティブで提供します。
1.json_encode()
この関数は、php の配列とオブジェクトを json 形式に変換します。
eg:array $arr = array ('a'=>1,'b'=>2,'c'=>3,'d'=>4,'e'=>5); echo json_encode($arr); result:{"a":1,"b":2,"c":3,"d":4,"e":5} eg:object $obj->body = 'another post'; $obj->id = 21; result: { "body":"another post", "id":21, }
2. インデックス付き配列と連想配列
PHP は 2 種類の配列をサポートしており、1 つは "value" (value) のみを保存するインデックス付き配列で、もう 1 つはインデックス付き配列です。は、名前と値のペアを格納する連想配列です。
JavaScript は連想配列をサポートしていないため、json_encode() はインデックス付き配列のみを配列形式に変換し、連想配列をオブジェクト形式に変換します。
たとえば、インデックス配列が存在します。
$arr = Array('one', 'two', 'three');
echo json_encode ($ arr);
結果は次のとおりです:
["one","two","three"]
Ifあなたがそれを変更します 連想配列の場合:
$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 = 'これはprivate!';
protected $protected_ex = 'これは保護する必要があります';
}
# }
ここで、このクラスのインスタンスに対して json 変換を実行します:
$foo = new Foo;
$foo_json = json_encode($foo);
echo $foo_json;
出力結果は
{"public_ex":"this is public"}
あなた到着しました。 パブリック変数 (パブリック) に加えて、他のもの (定数、プライベート変数、メソッドなど) が失われます 。
[推奨学習: PHP ビデオ チュートリアル ]
4. json_decode()
この関数は、json を変換するために使用されます。 text 対応する PHP データ構造に変換します。以下に例を示します。
$json = '{"foo": 12345}';
$obj = json_decode($json);print $ obj->gt;{'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)
["d"] => int(4)
["e"] => int(5)}
PHP 連想配列を強制的に生成するには、json_decode() でパラメーター true を追加する必要があります:
$json = '{"a":1,"b" :2,"c":3 ,"d":4,"e":5}';array(5) {#結果が生成されます 連想配列:
var_dump(json_decode($json),true);
5. json_decode() のよくあるエラー["a"] => int(1)
[" b"] => int( 2)["c"] => int(3)
["d"] => int(4)
["e"] => ; int(5)
}
次の 3 つの json の記述方法はすべて、間違っています。どこが間違っているか分かりますか?
$bad_json = "{ 'bar': 'baz' }";$bad_json = '{ bar: "baz" }';
$ bad_json = '{ "バー": "バズ", }';
これら 3 つの文字列に対して json_decode() を実行すると、null が返され、エラーが報告されます。
最初の間違いは、JSON 区切り文字 (区切り文字) では、一重引用符ではなく二重引用符の使用のみが許可されていることです。 2 番目のエラーは、json name 値ペアの「名前」 (コロンの左側の部分) では、 いかなる場合でも二重引用符 を使用する必要があることです。 3 番目のエラーは、最後の値の後にカンマを追加できないことです。
さらに、json はオブジェクトと配列を表すためにのみ使用できます。文字列または値に対して json_decode() を使用すると、null が返されます。
var_dump(json_decode("Hello World")); //null
以上がPHPのJSON形式を変換する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。