Заполните обычный старый PHP-объект содержимым JSON.
Вы можете установить эту библиотеку с помощью Composer:
composer require abgeo/json-to-popo
Включите автозагрузчик композитора в ваш основной файл (например: index.php).
require __DIR__.'/../vendor/autoload.php';
Предположим, у вас есть example.json
со следующим содержимым:
{
"firstName" : " Temuri " ,
"lastName" : " Takalandze " ,
"active" : true ,
"position" : {
"title" : " Developer " ,
"department" : {
"title" : " IT "
}
}
}
и несколько классов POPO для представления этих данных 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...
}
Примечание . Все свойства POPO должны иметь полную аннотацию @var
с правильным типом данных.
Теперь вы хотите преобразовать этот json to popo с отношениями. Этот пакет дает вам такую возможность.
Давайте создадим новый объект ABGEOPOPOComposer
и прочитаем содержимое example.json
:
$ composer = new Composer ();
$ jsonContent = file_get_contents ( __DIR__ . ' /example.json ' );
Время волшебства! Вызовите функцию composeObject()
с содержимым JSON и основного класса, и это даст вам POPO:
$ resultObject = $ composer -> composeObject ( $ jsonContent , Person::class);
Напечатайте $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"
// }
// }
//}
Полный пример смотрите здесь.
Подробности смотрите в CHANGELOG.
Запросы на вытягивание приветствуются. Если вы хотите внести существенные изменения, пожалуйста, сначала откройте вопрос, чтобы обсудить, что вы хотели бы изменить.
Обязательно обновляйте тесты по мере необходимости.
Copyright © 2020 Темури Такаландзе.
Выпущено по лицензии MIT.