对于联系表格,我有两个实体。
class ContactRequest
{
/**
* @var int
*
* @ORM\Column(name="id", type="integer")
* @ORM\Id
* @ORM\GeneratedValue(strategy="AUTO")
*/
private $id;
[...]
/**
* @ORM\ManyToOne(targetEntity="ContactCategory")
* @ORM\Column(name="type", type="integer")
*/
private $type;
/**
* @var string
*
* @ORM\Column(name="message", type="text", nullable=false)
*/
private $message;
[...]
}
和
class ContactCategory
{
/**
* @var int
*
* @ORM\Column(name="id", type="integer")
* @ORM\Id
* @ORM\GeneratedValue(strategy="AUTO")
*/
private $id;
[...]
public function __toString()
{
return $this->getName();
}
}
然后我的表格
class ContactRequestType extends AbstractType
{
public function buildForm(FormBuilderInterface $builder, array $options)
{
$builder->add('requesterFirstname', Type\TextType::class, array('label' => 'Prénom'))
->add('requesterLastname', Type\TextType::class, array('label' => 'Nom'))
->add('requesterMail', Type\EmailType::class, array('label' => 'Email'))
->add('requesterPhone', Type\TextType::class, array('label' => 'Téléphone'))
->add('message', Type\TextareaType::class, array('label' => 'Message'))
$builder->add('type', EntityType::class, [
'class' => 'CargoApiBundle:ContactCategory',
'group_by' => 'group',
'query_builder' => function (EntityRepository $er) use ( $options ) {
return $er->createQueryBuilder('cc')
->where('cc.site = :site')->setParameter('site', $options['site'])
->orderBy('cc.group', 'ASC')
->orderBy('cc.name', 'ASC');
}
]);
}
public function configureOptions(OptionsResolver $resolver)
{
$resolver->setDefaults([
'short' => false,
'site' => null,
'data_class' => 'Cargo\ApiBundle\Entity\ContactRequest'
]);
}
}
显示效果很好但是当我提交表单时,它会在类型字段“此值应为整数类型”上引发错误。似乎是合乎逻辑的,因为它必须是我的联系人类别的ID。
所以我查看了表单生成的代码,发现没有错:
<select id="contact_request_type" name="contact_request[type]" class="form-control">
<optgroup label="Général">
<option value="4">Autre</option>
<option value="3">Du partenariat/sponsoring</option>
<option value="1">Le fonctionnement de l'association</option>
<option value="2">Un tournoi internationnal</option>
</optgroup>
<optgroup label="Une section">[...]</optgroup>
<optgroup label="Le site">[...]</optgroup>
</select>
所以我转储了请求内容以查看提交的内容并得到了这个:
array (size=3)
'action' => string 'contact_send' (length=12)
'contact_request' =>
array (size=7)
'requesterFirstname' => string 'Kiro' (length=5)
'requesterLastname' => string 'Staz' (length=4)
'requesterMail' => string 'me@me.com' (length=18)
'requesterPhone' => string '0000000000' (length=10)
'type' => string '2' (length=1)
'message' => string 'test' (length=17)
'_token' => string '32LuZWWh8h-6lMlEShrjrs1w5HspaX0R4WikcGf5u3o' (length=43)
我的数据是严格的,但contact_request ['type']被转储为字符串,我认为问题,它应该是一个整数类型被验证为整数。
有人能给我一些我做错的线索吗?
我没有自定义约束验证器。
谢谢!
答案 0 :(得分:0)
关联字段不应该有任何@Column
注释。 Doctrine会根据ContactCategory
主键的类型确定它应该是什么类型的列。
删除
* @ORM\Column(name="type", type="integer")
来自ContactRequest::$type