Preencha o objeto PHP simples e antigo com conteúdo JSON.
Você pode instalar esta biblioteca com o Composer:
composer require abgeo/json-to-popo
Incluir o compositor autoloader no seu arquivo principal (Ex.: index.php)
require __DIR__.'/../vendor/autoload.php';
Considere que você tem example.json
com o seguinte conteúdo:
{
"firstName" : " Temuri " ,
"lastName" : " Takalandze " ,
"active" : true ,
"position" : {
"title" : " Developer " ,
"department" : {
"title" : " IT "
}
}
}
e várias classes POPO para representar esses dados JSON:
Department.php
<?php
class Department
{
/**
* @var string
*/
private $ title ;
// Getters and Setters here...
}
Position.php
<?php
class Position
{
/**
* @var string
*/
private $ title ;
/**
* @var ABGEOPOPOExampleDepartment
*/
private $ department ;
// Getters and Setters here...
}
Person.php
<?php
class Person
{
/**
* @var string
*/
private $ firstName ;
/**
* @var string
*/
private $ lastName ;
/**
* @var bool
*/
private $ active ;
/**
* @var ABGEOPOPOExamplePosition
*/
private $ position ;
// Getters and Setters here...
}
Nota : Todas as propriedades POPO devem ter a anotação @var
totalmente qualificada com o tipo de dados correto.
Agora você deseja converter este json to popo com relações. Este pacote oferece essa capacidade.
Vamos criar um novo objeto ABGEOPOPOComposer
e ler o conteúdo example.json
:
$ composer = new Composer ();
$ jsonContent = file_get_contents ( __DIR__ . ' /example.json ' );
Hora da magia! Chame composeObject()
com o conteúdo do JSON e da classe principal, e isso lhe dará POPO:
$ resultObject = $ composer -> composeObject ( $ jsonContent , Person::class);
Imprimir $resultObject
:
var_dump ( $ resultObject );
//class ABGEOPOPOExamplePerson#2 (4) {
// private $firstName =>
// string(6) "Temuri"
// private $lastName =>
// string(10) "Takalandze"
// private $active =>
// bool(true)
// private $position =>
// class ABGEOPOPOExamplePosition#4 (2) {
// private $title =>
// string(9) "Developer"
// private $department =>
// class ABGEOPOPOExampleDepartment#7 (1) {
// private $title =>
// string(2) "IT"
// }
// }
//}
Veja o exemplo completo aqui.
Consulte CHANGELOG para obter detalhes.
Solicitações pull são bem-vindas. Para mudanças importantes, abra primeiro uma edição para discutir o que você gostaria de mudar.
Certifique-se de atualizar os testes conforme apropriado.
Direitos autorais © 2020 Temuri Takalandze.
Lançado sob a licença do MIT.