我在Symfony上为一个明显具有密码属性的用户实体编写验证。
namespace AppBundle\Entity;
...
class User implements UserInterface {
...
/**
* @ORM\Column(type="string")
*/
private $password;
/**
* @Assert\NotBlank(message="Veuillez indiquer un mot de passe")
* @Assert\Length(
* min=8,
* max=4096,
* minMessage="Votre mot de passe doit contenir au moins {{limit}} cacactères",
* maxMessage="Votre mot de passe ne doit pas contenir plus de {{limit}} caractères"
* )
*/
private $plain_password;
...
}
如您所见,我阻止密码为空,并检查其长度是否大于或等于8个字符。
但另外,在注册表单中,我添加了密码确认,感谢"重复"由Symfony提供的类型(我更喜欢提及因为我觉得这是我问题的根源)。
namespace AppBundle\Form;
use Symfony\Component\Form\AbstractType;
use Symfony\Component\Form\FormBuilderInterface;
use Symfony\Component\OptionsResolver\OptionsResolver;
use Symfony\Component\Form\Extension\Core\Type\EmailType;
use Symfony\Component\Form\Extension\Core\Type\PasswordType;
use Symfony\Component\Form\Extension\Core\Type\UrlType;
use Symfony\Component\Form\Extension\Core\Type\RepeatedType;
use Symfony\Component\Form\Extension\Core\Type\SubmitType;
class UserFormType extends AbstractType {
public function buildForm(FormBuilderInterface $builder, array $options) {
$builder
->add('email', EmailType::class)
->add('plain_password', RepeatedType::class, [
'type' => PasswordType::class,
'first_name' => 'first',
'second_name' => 'confirmation',
'invalid_message' => 'La confirmation ne correspond pas avec le mot de passe'
])
->add('firstname')
->add('lastname')
->add('city')
->add('website', UrlType::class)
->add('facebook')
->add('twitter')
->add('instagram')
->add('avatar')
->add('submit', SubmitType::class);
}
public function configureOptions(OptionsResolver $resolver) {
$resolver->setDefaults([
'data_class' => 'AppBundle\Entity\User'
]);
}
}
现在,当我提交表单时,将密码字段留空,我会收到正确的消息" Veuillez indiquer un mot de passe" (如你所见的法语)。
当我在两个密码字段中提交具有不同值的表单时,我也会得到正确的消息" La确认对应的avec le mot de passe" 。
但是,当我在两个密码字段中提交具有相等而非空白值的表单,但长度低于8;我没有任何错误消息,用户被安静地保存。
Symfony还在嘲笑我吗?我曾经处理过没有造成这种无聊问题的铁轨......
阿尔萨斯:我没有为表单设置验证组
控制器操作:
public function signupAction(Request $request) {
$user = new User();
$form = $this->createForm(UserFormType::class, $user);
$form->handleRequest($request);
if($form->isSubmitted() && $form->isValid()) {
$em = $this->getDoctrine()->getManager();
$em->persist($user);
$em->flush();
return $this->redirectToRoute('home');
}
return $this->render('user/signup.html.twig', [
'form' => $form->createView()
]);
}