我试图反序列化这个非常简单的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>
无论我尝试什么,我都不能将参数元素反序列化为array
或ArrayCollection
或任何种类的集合,因为该数组总是以空结尾。
/**
* @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;
请注意该类中的@XmlList
属性Argument
。您也可以删除getter和setter!
本文收集自互联网,转载请注明来源。
如有侵权,请联系[email protected] 删除。
我来说两句