バージョン 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;お気に入り数 = 1;
$obj->status = NULL;
結果は
コードをコピーします コードは次のとおりです:
{ "body": "another post",
"id": 21,
"approved ": true,
"favorite_count": 1,
"status":null
}
json は utf-8 でエンコードされた文字のみを受け入れるため、json_encode() のパラメーターutf-8 でエンコードされている必要があります。そうでない場合は、空の文字または null が返されます。中国語で GB2312 エンコードを使用する場合、または外国語で ISO-8859-1 エンコードを使用する場合は、この点に特別な注意を払う必要があります。
コードをコピー コードは次のとおりです:
$arr = Array('one' , 'two', 'three'); echo json_encode($arr);
結果は次のようになります:
コード class Foo {
const ERROR_CODE = '404'; public $public_ex = 'これはパブリックです'
private $private_ex = 'これはプライベートです!';
protected $protected_ex = 'これは保護されるべきです';
public function getErrorCode() {
return self::ERROR_CODE; 🎜> 次に、このクラスのインスタンスで json 変換を実行します。 🎜>
コードをコピーします
コードは次のとおりです。
echo $foo_json; 出力結果は {"public_ex":"this is public"}
はい、パブリック変数 (public) を除きます。 、他のもの(定数、プライベート変数、メソッドなど)がありません。
4. json_decode()
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)
["d"] => int(4)
["e"] => int(5)
コードをコピー コードは次のとおりです。
array(5) {
["a"] => int(1)
[" b"] => int(2)
["c"] => int(3)
["d"] => int(4)
["e"] => ; int(5)
}
コードをコピー コードは次のとおりです。
$bad_json = "{ 'bar': 'baz' }";
$bad_json = '{ bar: "baz" }';
$bad_json = '{ "bar": "baz", }'