2017-04-12 66 views
0

我得到了以下实体领域:Symfony的串行器返回字符串,而不是数组

/** 
* @var array 
* 
* @ORM\Column(name="field", type="array", length=65535, nullable=true) 
*/ 
private $field; 

/** 
* Set field 
* 
* @param array $field 
* 
* @return array 
*/ 
public function setField($field) 
{ 
    $this->field= $field; 

    return $this; 
} 

/** 
* Get field 
* 
* @return array 
*/ 
public function getField() 
{ 
    return $this->field; 
} 

我收到以下领域的JSON:

{"field":["9031234567,9031234568,9031234569"]} 

,并使用Symfony的串行代码:

$filter = $em->getRepository('AppBundle:Filter')->findOneBy(['id' => $id]); 
$encoders = array(new XmlEncoder(), new JsonEncoder()); 
$normalizers = array(new ObjectNormalizer()); 
$serializer = new Serializer($normalizers, $encoders); 
$serializer->deserialize($_POST['data'], Filter::class, 'json', array('object_to_populate' => $filter)); 
$em->persist($filter); 
$em->flush(); 

将我的字段保存到Filter实体中。问题是,在我的数据库我得到这个:

a:1:{i:0;s:32:"9031234567,9031234568,9031234569";} //saved as 1 string 

,而我需要这样的:

a:3:{i:0;d:9031234567;i:1;d:9031234568;i:2;d:9031234569;} //every number saved in a separate string 

任何想法如何解决呢?谢谢。

UPD我的串行器返回如下:

["field":"AppBundle\Entity\Filter":private]=> 
array(1) { 
[0]=> 
string(64) "903255, 345345, 46546, 46546, 46546, 46546, 46546, 46546, 
46546," 

回答

0

如果你想给每个字段项存储到数据库,你可以使用的ArrayCollection进行反序列化JSON。

检查this Symfony文档的主题。

我想念你的实体注释。 如果你想数组项存储到一个记录,可以这样做:

/** 
* Constructor. 
*/ 
public function __construct() 
{ 
    $this->fields = new ArrayCollection(); 
} 

Add方法添加项目到实体(更新)

/** 
* @param array $fields 
* @return  $this 
*/ 
public function addFields(array $fields) 
{ 
    $this->fields = $fields; 

    return $this; 
} 

当你要存储数据到DB你只需要:

$elementsToDb = ['12345', '67890', '1234567']; 
$fields = new Field(); 
$fields->addFields($elementsToDb); 
$this->entityManager->persist($fields); 
$this->entityManager->flush($fields); 

问候。

+0

如何在我的代码中使用此addField()方法,其中$ serializer-> deserialize()被调用? – Jack

+0

答案已经更新。 – Viktor

+1

你能提供什么反序列化器返回? – Viktor

相关问题