我尝试学习使用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,
]);
}