繁体   English   中英

使用JMS Serializer进行XML反序列化

[英]XML deserialization with JMS Serializer

我试图反序化这个非常简单的XML:

<?xml version="1.0" encoding="utf-8"?>
<root>
    <namespace>foo</namespace>
    <resource>bar</resource>
    <description>baz</description>
    <arguments>
        <argument>
            <name>foo</name>
            <type>string</type>
            <description>foo</description>
        </argument>
        <argument>
            <name>bar</name>
            <type>string</type>
            <description>bar</description>
        </argument>
    </arguments>
</root>

无论我尝试什么,我都不能将arguments元素反序列化为arrayArrayCollection或任何类型的集合,因为数组总是空的。

/**
 * @Type("array<Model\Argument>")
 */
private $arguments;

/**
 * @Type("ArrayCollection<Model\Argument>")
 */
private $arguments;

两者最终都是空数组。 所以我尝试为参数创建一个单独的对象

因此,原始财产最终成为

/**
 * @Type("Model\Arguments")
 */
private $arguments;

和班级

class Arguments {
    /**
     * @Type("array<App\Blueprint\Model\Argument>")
     */
    private $arguments;

    /**
     * @return mixed
     */
    public function getArguments() {
        return $this->arguments;
    }

    /**
     * @param mixed $arguments
     */
    public function setArguments($arguments) {
        $this->arguments = $arguments;
    }
}

数组仍然是空的。 但是,当我将类型更改为@Type("App\\Blueprint\\Model\\Argument")我将获得正确的对象,尽管只有第一个。

当我尝试注册反序列化处理程序时,我无法修改它,因为它是SimpleXmlElement然后我会得到It is not yet possible to assign complex types to properties警告...

编辑

现在我设法以一种愚蠢的方式解决它:

$registry->registerHandler(
    'deserialization',
    'Model\Arguments',
    'xml',
    function(XmlDeserializationVisitor $visitor, $data, array $type, DeserializationContext $context) {
        $arguments = [];
        foreach($data->children() as $child) {
            $arguments[] = SerializerBuilder::create()
                ->build()
                ->deserialize($child->asXML(), 'Model\Argument', 'xml');
        }

        return $arguments;
    }
);

如果有人有更好的解决方案,就把它留在这里。

你很亲密。 您必须定义两个单独的类。

/**
 * @Type("Model\Arguments")
 */
public $arguments;
/**
 * @Type("array<Model\Argument>")
 * @XmlList(inline = true, entry = "argument")
 */
public $argument;

注意Argument类中的@XmlList属性。 你也可以删除getter和setter!

为我工作,但不确定这是这样的:

我的XML:

<activityData>
    <count>1</count>
    <facts>
        <fact>
            <dateTime year="2016" month="11" day="14" hour="0" minute="0" second="0" />
            <channel>Administrator</channel>
            <count>1</count>
        </fact>
    </facts>
</activityData>

所以我的模特:

1。

class ActivityData
{
    /**
     * @var ArrayCollection|ActivityDataFact[]
     *
     * @Serializer\Type("ArrayCollection<AppBundle\Model\ActivityDataFact>")
     * @Serializer\XmlList(entry="fact")
     */
    private $facts;
    ...
}

2。

class ActivityDataFact
{
    /**
     * @var DateTime
     *
     * @Serializer\Type("AppBundle\Model\DateTime")
     * @Serializer\SerializedName("dateTime")
     */
    private $date;

    /**
     * @var string
     *
     * @Serializer\Type("string")
     */
    private $channel;

    /**
     * @var integer
     *
     * @Serializer\Type("integer")
     */
    private $count;
    ...
}

3。

class DateTime
{
    /**
     * @var string
     *
     * @Serializer\Type("integer")
     * @Serializer\XmlAttribute()
     */
    private $year = 1970;

    /**
     * @var string
     *
     * @Serializer\Type("integer")
     * @Serializer\XmlAttribute()
     */
    private $month = 1;

    /**
     * @var string
     *
     * @Serializer\Type("integer")
     * @Serializer\XmlAttribute()
     */
    private $day = 1;

    /**
     * @var string
     *
     * @Serializer\Type("integer")
     * @Serializer\XmlAttribute()
     */
    private $hour = 0;

    /**
     * @var string
     *
     * @Serializer\Type("integer")
     * @Serializer\XmlAttribute()
     */
    private $minute = 0;

    /**
     * @var string
     *
     * @Serializer\Type("integer")
     * @Serializer\XmlAttribute()
     */
    private $second = 0;
    ...
}

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM