自定义表格仅接受特定的电子邮件地址fosuserbundle 2.0/ symfony3



我尝试学习使用Symfony 3.1.10创建网站。为了帮助我进行我的项目创建登录/注册,我决定使用" FosuserBundle 2.0"捆绑包。因此,现在我创建了一个自定义表单(我按名称字段更改了用户名字段(。对于我的项目,我试图允许仅注册用户特定的电子邮件地址。因此,经过很少的研究,他们解释了创造自定义行为的解释,FosuserBundle创建了事件。因此,当我有registration_success时,我可以创建自定义事件侦听器,如下所示。

class CheckEmailBefore implements EventSubscriberInterface {
private $router;
private $request;
public function __construct(RouterInterface $router,Request $request)
{
    $this->router = $router;
    $this->request = $request;
}
public static function getSubscribedEvents() {
    return [
        FOSUserEvents::REGISTRATION_SUCCESS => 'onCheck'
    ];
}

/**
 * @param FormEvent $event
 *
 */
public function onCheck(FormEvent $event){
    $user = $event->getForm()->getData();
    $email = $user->getEmailCanonical();
    $format = explode("@",$email);
    if((strcmp($format[1] , "truc.com")===0) || (strcmp($format[1] , "chose.com") === 0)){
        $url = $this->router->generate('list');
        $response = new RedirectResponse($url);
        $event->setResponse($response);

    }else{
        $event->getForm()->addError(new FormError("Enter a mail address with valid format"), 1);
        var_dump($event->getForm()->getErrors());
        die("Address is not valid");
    }



}
}

我的问题是一旦添加了一个错误,我就不知道如何在我的表单上显示它,例如捆绑包已经创建的错误。

预先感谢。

我不会为此使用事件调度程序组件,我将更简单并创建一个自定义验证约束。这是文档的链接。

您可以创建一个约束,可以检查一下您的用户是否在电子邮件中具有特定域。是约束不会通过,验证将失败,因此,注册过程为您提供了正确的错误信息。

文档的解释非常好,但是如果您需要帮助时,请告诉我,我可以更新我的答案。

更新:

class RegistrationForm extends OtherForm
{
    public function buildForm(FormBuilderInterface $builder, array $options)
    {
        parent::buildForm($builder, $options);
        $builder
            ->add('firstName', TextType::class, [
                'required' => true,
                'constraints' => [
                    new NotBlank(),
                    new Length(['min' => 2, 'max' => 20]),
                ]
            ])
            ->add('lastName', TextType::class, [
                'required' => true,
                'constraints' => [
                    new NotBlank(),
                    new Length(['min' => 2, 'max' => 20]),
                ]
            ])
            ->add('secondLastName', TextType::class, [
                'required' => true,
                'constraints' => [
                    new NotBlank(),
                    new Length(['min' => 2, 'max' => 20]),
                ]
            ])
            ->add('email', TextType::class, [
                'required' => true,
                'constraints' => [
                    new NotBlank(),
                    new CustomConstraint(),
                    new Length(['min' => 2, 'max' => 20]),
                ]
            ])
        ;
    }
    public function configureOptions(OptionsResolver $resolver)
    {
        $resolver->setDefaults([
            'data_class' => User::class,
            'csrf_protection' => false,
            'allow_extra_fields' => true,
        ]);
    }

最新更新