2

在我的表单上,我使用的novalidate是这样的属性:

{{ form_start(form, {'attr': {novalidate: 'novalidate'}}) }}                

禁用 HTML5 浏览器验证。因此出现 Symfony 断言错误。在 new.html.twig 页面上它工作得非常好!novalidate 属性禁用 html5 验证并出现断言错误。

但是,当我在 edit.html.twig 上使用 novalidate 属性并将该username字段留空(我不在表单上填写)时,@Assert\NotBlank()它不起作用。我得到这个错误

属性路径“用户名”中给出的“字符串”类型的预期参数,“空”。

为什么symfony assert 在新页面上工作,但在编辑页面上不起作用?顺便说一句,我没有使用任何验证组。

这是我的用户实体的代码(没有 getter 和 setter):

class User implements UserInterface
{
    /**
     * @ORM\Id()
     * @ORM\GeneratedValue()
     * @ORM\Column(type="integer")
     */
    private $id;

    /**
     * @ORM\Column(type="string", length=255)
     * @Assert\Email()
     * @Assert\NotBlank()
     */
    private $email;

    /**
     * @ORM\Column(type="string", length=255)
     * @Assert\NotBlank()
     */
    private $username;

    /**
     * @ORM\Column(type="string", length=255)
     * @Assert\NotBlank()
     * @Assert\Length(
     *      min = 8, max = 30,
     *      minMessage = "Your password must be between 6 and 30 characters.")     
     */
    private $password;
    
    /**
     * @ORM\Column(type="json", nullable=true )
     */
    private $roles = [];

这是表单的代码:

class UserType extends AbstractType
{
    public function buildForm(FormBuilderInterface $builder, array $options)
    {
        $builder
            ->add('email', EmailType::class )
            ->add('username', TextType::class)
            ->add('password',PasswordType::class)
        ;
    }

    public function configureOptions(OptionsResolver $resolver)
    {
        $resolver->setDefaults([
            'data_class' => User::class,
        ]);
    }
}

new.html.twig 和 edit.html.twig 都有相同的代码:

{{ form_start(form, {'attr': {novalidate: 'novalidate'}}) }}    

    {{ form_widget(form.email, {'attr': {'class': 'form-control',placeholder: 'Email Adress'} }) }}     
    {{form_errors(form.email)}}

    {{ form_widget(form.username, {'attr': {'class': 'form-control',placeholder: 'Username'} }) }}
    {{form_errors(form.username)}}

    {{ form_widget(form.password, {'attr': {'class': 'form-control'} }) }}
    {{form_errors(form.password)}}

    <button class="btn btn-success">Submit</button>
{{ form_rest(form) }}
{{ form_end(form) }}

控制器代码:

/**
 * @Route("/new", name="user_new", methods={"GET","POST"})
 */
public function new(Request $request): Response
{
    $user = new User();
    $form = $this->createForm(UserType::class, $user);
    $form->handleRequest($request);

    if ($form->isSubmitted() && $form->isValid()) {
        $entityManager = $this->getDoctrine()->getManager();
        $entityManager->persist($user);
        $entityManager->flush();

        return $this->redirectToRoute('user_index');
    }

    return $this->render('user/new.html.twig', [
        'user' => $user,
        'form' => $form->createView(),
    ]);
}


/**
 * @Route("/{id}/edit", name="user_edit", methods={"GET","POST"})
 */
public function edit(Request $request, User $user): Response
{
    $form = $this->createForm(UserType::class, $user);
    $form->handleRequest($request);

    if ($form->isSubmitted() && $form->isValid()) {
        $this->getDoctrine()->getManager()->flush();

        return $this->redirectToRoute('user_index');
    }

    return $this->render('user/edit.html.twig', [
        'user' => $user,
        'form' => $form->createView(),
    ]);
}

我的吸气剂和二传手:

public function getEmail(): ?string
{
    return $this->email;
}

public function setEmail(string $email): self
{
    $this->email = $email;

    return $this;
}
public function getUsername(): ?string
{
    return $this->username;
}

public function setUsername(string $username): self
{
    $this->username = $username;

    return $this;
}


public function getPassword(): ?string
{
    return $this->password;
}

public function setPassword(string $password): self
{
    $this->password = $password;

    return $this;
}
4

1 回答 1

2

我认为您应该?在所有设置器上为字符串类型添加符号。

例如将其从更改 setUsername(string $username): self setUsername(?string $username): self

这应该可以解决编辑页面上的断言问题。

于 2020-09-26T14:30:21.473 回答