1

そのため、ユーザーがプロファイルの詳細 (名前、電子メールなど) を更新できるフォームがあります。

ユーザー エンティティを指すフォーム タイプ (UserType) を使用して、フォームが正しく表示されます。UserType は、ユーザー名、電子メールを使用してフォームを作成し、ProfileType (本名、住所などを含む別のフォーム タイプ) に拡張します。

前述したように、フォームはページに正しく表示されます。

ここで、validation.yml ファイルでは、User エンティティと Profile エンティティの両方を指しています。User については、ユーザー名、電子メール、パスワードの 3 つの検証ルールを定義しています。プロフィールについては、名前と会社名のルールを定義しています。すべてのルールには NotBlank があり、電子メールにもそれが有効であることを確認するチェックがあり、パスワードには最大長と最小長が定義されています。

さて、最近パスワードルールが追加されました。以前は、このフォームは問題なく機能していました。

パスワード規則を追加すると、フォームが送信されると、この検証規則に対してチェックが試行されますが、ページに表示されるパスワード フィールドはなく、フォーム タイプの UserType にも記載されていません。

確かに、入力を使用しない場合、検証ルールに対してチェックするべきではありませんか?

以下のコード:

検証.yml

DEMO\DemoBundle\Entity\User\Profile:
properties:
    name:
        - NotBlank: ~
    pubName:
        - NotBlank: ~

DEMO\DemoBundle\Entity\User\User:
    properties:
        username:
            - NotBlank:
                message: Username cannot be blank.
        email:
            - NotBlank: ~
            - Email:
                message: The email "{{ value }}" is not a valid email.
                checkMX: true
        password:
            - MaxLength: { limit: 20, message: "Your password must not exceed {{ limit }} characters." }
            - MinLength: { limit: 4, message: "Your password must have at least {{ limit }} characters." }
            - NotBlank: ~

UserType.php

namespace DEMO\DemoBundle\Form\Type\User;

use Symfony\Component\Form\AbstractType;
use Symfony\Component\Form\FormBuilder;
use Symfony\Component\Form\FormError;
use Symfony\Component\Form\CallbackValidator;

use DEMO\DemoBundle\Form\Type\User\ProfileType;

class UserType extends AbstractType
{
    public function buildForm(FormBuilder $builder, array $options)
    {
        $builder->add('username');
        $builder->add('email');
        $builder->add('profile', new ProfileType());
    }

    public function getDefaultOptions(array $options)
    {
        return array(
            'data_class' => 'DEMO\DemoBundle\Entity\User\User',
        );
    }

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

ProfileType.php

namespace DEMO\DemoBundle\Form\Type\User;

use Symfony\Component\Form\AbstractType;
use Symfony\Component\Form\FormBuilder;
use Symfony\Component\Form\FormError;
use Symfony\Component\Form\CallbackValidator;

class ProfileType extends AbstractType
{
    public function buildForm(FormBuilder $builder, array $options)
    {
        $builder->add('name');
        $builder->add('companyName', null, array('label' => 'Company Name'));
        $builder->add('address1', null, array('label' => 'Address 1'));
        $builder->add('address2', null, array('label' => 'Address 2'));
        $builder->add('city');
        $builder->add('county');
        $builder->add('postcode');
        $builder->add('telephone');
    }

    public function getDefaultOptions(array $options)
    {
        return array(
            'data_class' => 'DEMO\DemoBundle\Entity\User\Profile',
        );
    }

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

DashboardController.php

public function profileAction(Request $request)
    {

        $user = $this->get('security.context')->getToken()->getUser();

        $form = $this->createForm(new UserType(), $user);

        if ($request->getMethod() == 'POST') {
            $form->bindRequest($request);

            if ($form->isValid()) {
                // Get $_POST data and submit to DB
                $em = $this->getDoctrine()->getEntityManager();
                $em->persist($user);
                $em->flush();

                // Set "success" flash notification
                $this->get('session')->setFlash('success', 'Profile saved.');
            }

        }

        $breadcrumbs = $this->get("white_october_breadcrumbs");
        $breadcrumbs->addItem("Home", $this->get("router")->generate("shop"));
        $breadcrumbs->addItem("My Account", $this->get("router")->generate("shop"));
        $breadcrumbs->addItem("My Profile", $this->get("router")->generate("shop"));

        return $this->render('DEMODemoBundle:User\Dashboard:profile.html.twig', array('form' => $form->createView()));
    }

profile.html.twig

<div class="container">
    <div class="row">
        <div class="span12">
            {% form_theme form 'DEMODemoBundle:User\\Form:fields.html.twig' %}

            {{ form_errors(form) }}

            <form action="{{ path('tk_update_profile') }}" class="form-horizontal" method="post" {{ form_enctype(form) }} novalidate="novalidate">
                <fieldset>
                    <legend>Your Details</legend>
                    {{ form_row(form.username) }}
                    {{ form_row(form.profile.name) }}
                    {{ form_row(form.email) }}
                </fieldset>
                <fieldset>
                    <legend>Company Details</legend>
                    {{ form_row(form.profile.companyName) }}
                    {{ form_row(form.profile.address1) }}
                    {{ form_row(form.profile.address2) }}
                    {{ form_row(form.profile.city) }}
                    {{ form_row(form.profile.county) }}
                    {{ form_row(form.profile.postcode) }}
                    {{ form_row(form.profile.telephone) }}
                </fieldset>
                <fieldset>
                    <div class="form-actions">
                        {{ form_rest(form) }}
                        <input class="btn-primary" type="submit" value="Save" />
                        <input class="btn-warning" type="reset" value="Reset">
                    </div>
                </fieldset>
            </form>
        </div>
    </div>
</div>
4

1 に答える 1

3

ユーザー エンティティに基づいてフォームに入力すると、システムは新しいユーザー オブジェクトを作成し、エンティティに属するすべてのルールを検証しようとします。
必要なのは、基本的に「「編集」操作を行っているときに適用される制約を確認するだけ」と言う検証グループです。

ここで確認できます: http://symfony.com/doc/current/book/validation.html#validation-groups

于 2012-04-14T08:47:43.207 に答える