15

一意の電子メール フィールドしか持たない Customer エンティティがあります。顧客の電子メールを編集しようとしていますが、検証は正常に機能します。ただし、コントローラーにこれがあります:

public function updateAction(Request $request, $id) {
    $em = $this->getDoctrine()->getManager();

    $entity = $em->getRepository('AcmeDemoBundle:Customer')->find($id);

    if (!$entity) {
        throw $this->createNotFoundException('Unable to find Customer entity.');
    }


    $editForm = $this->createForm(new CustomerType(), $entity);
    $editForm->bind($request);
    if ($editForm->isValid()) {
        $em->persist($entity);
        $em->flush();

        return $this->redirect($this->generateUrl('ticket_result'));
    }
    var_dump($editForm->getErrors());

    return $this->render('AcmeDemoBundle:Customer:edit.html.twig', array(
                'entity' => $entity,
                'edit_form' => $editForm->createView(),
    ));
}

var_dump は空の配列を返しますが、バリデータは一意のエラーを設定し、$editForm->isValid()false を返します。検証中にコントローラーでその特定のエラーをチェックする方法はありますか?また、空のエラー配列を返す理由を説明できますか? 基本的に、そのエラーが発生した場合は「マージ」オプションを提供したいと思います。

編集:ここにフォームタイプがあります:

namespace Acme\DemoBundle\Form;

use Symfony\Component\Form\AbstractType;
use Symfony\Component\Form\FormBuilderInterface;
use Symfony\Component\OptionsResolver\OptionsResolverInterface;

class CustomerType extends AbstractType {


    public function buildForm(FormBuilderInterface $builder, array $options) {
        $builder
                ->add('email', 'email', array('required'=>true))
        ;

    }

    public function setDefaultOptions(OptionsResolverInterface $resolver) {
        $resolver->setDefaults(array(
            'data_class' => 'Acme\DemoBundle\Entity\Customer',
            'cascade_validation' => true,
        ));
    }

    public function getName() {
        return 'acme_demobundle_customertype';
    }
}

小枝テンプレート:

{% extends 'AcmeDemoBundle::layout.html.twig' %}
{% block body -%}
    <h1>Customer edit</h1>



  <form action="{{ path('customer_update', { 'id': entity.id }) }}" method="post" {{ form_enctype(edit_form) }}>
        <input type="hidden" name="_method" value="PUT" />
        {{ form_widget(edit_form) }}
        <p>
            <button type="submit">Edit</button>
        </p>
    </form>

{% endblock %}

これが私の検証です:

Acme\DemoBundle\Entity\Customer:
    constraints:
      - Symfony\Bridge\Doctrine\Validator\Constraints\UniqueEntity: 
          fields: email
          message: "A customer under that email address already exists"

    properties:
        email:
            - Email: ~
4

6 に答える 6

21

デバッグ目的で、Symfony 2.* を使用する場合$form->getErrorsAsString()の代わりに使用できます。$form->getErrors()

この回答から引用:

$form->getErrorsAsString()フォームをデバッグするためにのみ使用する必要があります... $form->getErrors() の場合とは異なり、各子要素のエラーが含まれます。


更新 1:

「より最近の Symfony バージョンでは、代わりに使用する必要があります$form->getErrors(true, false);。最初のパラメーターは " に対応しdeep、2 番目flattenのパラメーターは " (@Roubi によるコメントを参照)

于 2014-03-09T23:33:39.783 に答える
4

わかりました、ここで答えを見つけました:

エラーのない Symfony2 の無効なフォーム

各フォームの子には、独自の個別のエラーがあることがわかりました。のvar_dumpを行うとき

$editForm->getChildren()['email']->getErrors()

私は得る:

array (size=1)
  0 => 
    object(Symfony\Component\Form\FormError)[531]
      private 'message' => string 'A customer under that email address already exists' (length=50)
      protected 'messageTemplate' => string 'A customer under that email address already exists' (length=50)
      protected 'messageParameters' => 
        array (size=0)
          empty
      protected 'messagePluralization' => null

エラーメッセージ文字列を解析せずに、エラーが一意の競合によるものであると判断する方法をまだ疑問に思っています。

于 2013-07-16T12:22:01.710 に答える
0

Symfony 2.3 では、次のものを使用できます。

if ($form->isValid()){
    # Code...
} else {
    foreach ($form->getIterator() as $key => $child) {
        if ($child instanceof Form) {
            foreach ($child->getErrors() as $error) {
                $errors[$key] = $error->getMessage();
            }
        }
    }
}

$errorsこれにより、子からのエラーを含む配列 ( ) が取得されます。

于 2015-07-27T09:23:17.607 に答える