3
Sejak beberapa tahun kebelakangan JSON telah mengambil alih sebagai raja format pertukaran data. Sebelum JSON, XML memerintah roost. Ia hebat untuk memodelkan data kompleks tetapi sukar untuk menghuraikan dan sangat verbose. JSON benar -benar berlepas dengan percambahan tapak yang didorong oleh Ajax yang kaya kerana ia adalah format yang sangat mudah dibaca, cepat untuk menghuraikan dan perwakilan kunci/nilai mudahnya memotong semua kelebihan XML.
Sebelum antara muka jSonserializable tersedia, mengembalikan perwakilan yang dikodkan oleh JSON objek untuk perkhidmatan yang memakan bermakna salah satu daripada dua perkara.
Takeaways Key
Antara muka JSonserializable dalam Php 5.4.0 menawarkan cara yang lebih berkesan untuk mengembalikan perwakilan yang dikodkan oleh JSON objek, menghapuskan keperluan untuk membina struktur data di luar objek atau menginternalisasi fungsi pengekodan dalam objek.
Antara muka jSonserializable membolehkan pelaksanaan kaedah jSonserialize dalam kelas, yang secara automatik dicetuskan apabila contoh kelas adalah JSON yang dikodkan. Kaedah ini mengembalikan pelbagai data objek, memudahkan proses mengemas kini data jika perubahan diperlukan.
Seperti yang anda bayangkan, pendekatan ini dengan cepat menjadi menyusahkan. Bukan sahaja kita perlu menduplikasi kod array ini di seluruh permohonan kita, kita perlu ingat untuk mengemas kini semua keadaan apabila lebih banyak perubahan tidak dapat dielakkan. Ada cara lain, yang akan membantu kita membatalkan beberapa isu ini.
yang buruk
<span><span><?php </span></span><span> </span><span><span>class Customer </span></span><span><span>{ </span></span><span> </span><span> <span>private $email = null; </span></span><span> <span>private $name = null; </span></span><span> </span><span> <span>public function __construct($email, $name) </span></span><span> <span>{ </span></span><span> <span>$this->email = $email; </span></span><span> <span>$this->name = $name; </span></span><span> <span>} </span></span><span> </span><span> <span>public function getName() </span></span><span> <span>{ </span></span><span> <span>return $this->name; </span></span><span> <span>} </span></span><span> </span><span> <span>public function getEmail() </span></span><span> <span>{ </span></span><span> <span>return $this->email; </span></span><span> <span>} </span></span><span><span>} </span></span><span> </span><span><span>$customer = new Customer('customer@sitepoint.com', 'Joe'); </span></span><span> </span><span><span>$data = [ </span></span><span> <span>'customer' => [ </span></span><span> <span>'email' => $customer->getEmail(), </span></span><span> <span>'name' => $customer->getName() </span></span><span> <span>] </span></span><span><span>]; </span></span><span> </span><span><span>echo json_encode($data);</span></span>
Pendekatan ini mempunyai kelemahan sendiri, walaupun. Sesiapa sahaja yang datang dan ingin menggunakan pelanggan kami perlu mengetahui kaedah Tojson ini kerana ia bukan sesuatu yang mudah diperiksa, jadi kami memerlukan dokumentasi yang tepat. Kami juga perlu ingat bahawa kaedah ini
mengembalikan json sekarang, (walaupun kita boleh menggerakkan siri di luar kaedah). Ini menjadikan menggabungkan data pelanggan dengan sumber data lain yang lebih janggal kerana kita perlu berhati -hati untuk tidak menyandarkan hasil kaedah ini sekali lagi kerana itu akan menyebabkan beberapa bug jahat. yang baik
jadi, untuk perniagaan.
Seperti yang anda lihat, kami melaksanakan jSonserializable dengan menambahkan antara muka ke kelas kami dan kemudian menambahkan kaedah jSonserialize ke badan kelas kami untuk memenuhi kontrak antara muka.
<span><span><?php </span></span><span> </span><span><span>class Customer </span></span><span><span>{ </span></span><span> </span><span> <span>public $email = null; </span></span><span> <span>public $name = null; </span></span><span> </span><span> <span>public function __construct($email, $name) </span></span><span> <span>{ </span></span><span> <span>$this->email = $email; </span></span><span> <span>$this->name = $name; </span></span><span> <span>} </span></span><span> </span><span> <span>public function getName() </span></span><span> <span>{ </span></span><span> <span>return $this->name; </span></span><span> <span>} </span></span><span> </span><span> <span>public function getEmail() </span></span><span> <span>{ </span></span><span> <span>return $this->email; </span></span><span> <span>} </span></span><span> </span><span> <span>public function toJson() </span></span><span> <span>{ </span></span><span> <span>return json_encode([ </span></span><span> <span>'customer' => [ </span></span><span> <span>'email' => $this->getEmail(), </span></span><span> <span>'name' => $this->getName() </span></span><span> <span>] </span></span><span> <span>]); </span></span><span> <span>} </span></span><span><span>} </span></span><span> </span><span><span>$customer = new Customer('customer@sitepoint.com', 'Joe'); </span></span><span> </span><span><span>echo $customer->toJson();</span></span>
Keajaiban datang apabila anda ingin mencetuskan kaedah ini, yang perlu kita lakukan sekarang ialah JSON menyandarkan contoh kelas ini dan kaedah ini akan dipanggil secara automatik, pelbagai data yang dikembalikan dan kemudian dikodkan! Sekarang bahawa kelas melaksanakan antara muka yang kita mendapat manfaat daripada dapat memeriksa sama ada kelas ini adalah contoh JSonserializable. Sekiranya anda mahu, anda juga boleh menaip petunjuk dalam kaedah untuk memastikan antara muka jSonserializable diluluskan.
Dengan pelaksanaan mudah ini, kami telah menghapuskan pertindihan, menurunkan jumlah penyelenggaraan dan mengurangkan peluang memperkenalkan pepijat. Kami juga menjadikannya sepele untuk orang lain menggunakan kod kami untuk menguji keupayaan objek yang dikodkan dengan memeriksa sama ada ia adalah contoh jSonserializable.
Contoh -contoh di atas sudah tentu dirangka, bagaimanapun, saya harap saya telah berjaya menunjukkan manfaat menggunakan antara muka ini dan memberi inspirasi kepada anda untuk meneruskan dan menggunakannya sendiri.
Anda boleh menyesuaikan output JSON dengan mengembalikan struktur data tersuai dari kaedah jSonserialize (). Ini boleh menjadi array dengan kunci tersuai, rentetan, nombor, atau objek lain. Struktur data yang anda kembali dari jSonserialize () akan menjadi data yang dikodkan ke dalam json. susunan multidimensi. Jika tatasusunan mengandungi objek, setiap objek harus melaksanakan antara muka jSonserializable. Apabila json_encode () dipanggil pada pelbagai multidimensi, ia akan memanggil jSonserialize () pada setiap objek dalam array, yang membolehkan setiap orang menentukan bagaimana ia harus bersiri. Array? Jika array mengandungi objek, setiap objek harus melaksanakan antara muka jSonserializable. Apabila json_encode () dipanggil pada array yang tidak bersekutu, ia akan memanggil jSonserialize () pada setiap objek dalam array, yang membolehkan setiap orang menentukan bagaimana ia harus bersiri.
Atas ialah kandungan terperinci Cara Menggunakan Antara Muka JSonserializable. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!