enlumop/json2obj

支持目标类,易于使用的JSON到对象的转换工具

v0.0.3 2023-12-28 14:20 UTC

This package is auto-updated.

Last update: 2024-09-28 16:15:31 UTC


README

易于使用的Json 2 Object类转换器。

安装

Composer

composer require enlumop/json2obj

使用方法

首先在您的类中映射JSON属性

<?php

use Enlumop\JsonMapper\Attribute\JsonMap;

class MyDtoClass
{
    // If you need set base type then declarate type in mapper
    // You can use eg.  string, int, integer, bool, boolean, float
    #[JsonMap(type: 'string')]
    public string $name;

    // Sometimes json property name is diffrent. Then you can use other json property name to map class property.
    #[JsonMap(type: 'string', jsonPropertyName: 'shortlyUserName')]
    public string $shortName;

    #[JsonMap(type: 'int')]
    public int $age;

    // If property is the same as json property then you don't need to set a type
    #[JsonMap()]
    public bool $isFine;

     // Mapping is also working with a private and protected properties
    #[JsonMap()]
    private bool $isPrivate;

    // If structure of JSON is more complex then as type use classname
    #[JsonMap(type: OtherDto::class)]
    public OtherDto $other;

    /**
     * For array we need type of the values
     * @var array<string>
     */
    #[JsonMap(type: 'array<string>')]
    public array $stringArray;

    /**
     * For type of values array you can use clasename
     * @var array<OtherDto>
     */
    #[JsonMap(type: 'array<' . OtherDto::class . '>')]
    public array $objectsArray;
}

该类已为该JSON提供映射

{
    "name": "foo bar baz",
    "shortlyUserName": "bar",
    "age": "111",
    "isFine": true,
    "isPrivate": true,
    "other": {
        "anotherProperty": "another value"
    },
    "stringArray": [ "foo", "bar", "baz" ],
    "objectsArray": [
        {
            "anotherProperty": "other another value"
        },
        {
            "anotherProperty": "any other another value"
        }
    ]
}

然后,如果您在类中有一个JSON和映射,只需将其转换即可

<?php
use function Enlumop\JsonMapper\json2Obj;

// Get some json data
$json = "GIVE ME SOME JSON IN HERE";

// Convert json to object of MyDtoClass
$myObj = json2Obj(MyDtoClass::class, $json);

完成!您已经拥有了MyDtoClass对象!