1

小さなプロジェクトで Silex を使用していますが、一致する 2 つのパスワード フィールドを検証する方法がわかりません。また、データベース接続を使用して電子メールの一意性を確認する方法もわかりません。SF2のドキュメントでそれを理解できませんでした。

誰かが私にヒントやサンプルを教えてくれますか?

前もって感謝します

if ('POST' === $user->getMethod()) {

    $constraint = new Assert\Collection(array(
        'name' => array(new Assert\NotBlank(array('message' => 'Name shouldnt be blank'))),
        'username' => array(new Assert\NotBlank(), new Assert\MinLength(3)),
        'email' => array(new Assert\NotBlank(), new Assert\Email()),
        'password' => array(new Assert\NotBlank(), new Assert\MinLength(6)),
        'password2' => array(new Assert\NotBlank(), new Assert\MinLength(6)),
        'terms' => array(new Assert\True()),
    ));

    $errors = $app['validator']->validateValue($user->request->all(), $constraint); 

    if (!count($errors)) {
    //do something
    }
}
4

1 に答える 1

5

コメントで、あなたはすでにSf2フォームに切り替えていることがわかります。RepeatedType登録フォームの繰り返しパスワードフィールドに最適なフィールドが見つかったと思います。このフィールドには、2つの値が一致することを確認するためのチェックが組み込まれています。

もう1つの問題は、メールアドレスの一意性を確認することです。これが私の登録フォームの関連部分です:

<?php

namespace Insolis\Form;

use Symfony\Component\Form\AbstractType;
use Symfony\Component\Form\FormBuilderInterface;
use Symfony\Component\OptionsResolver\OptionsResolverInterface;
use Symfony\Component\Validator\Constraints as Assert;
use Symfony\Component\Validator\ExecutionContext;

class RegisterType extends AbstractType
{
    public function buildForm(FormBuilderInterface $builder, array $options)
    {
        $app = $options["app"];

        $builder->add("email", "email", array(
            "label"         =>  "E-mail address",
            "constraints"   =>  array(
                new Assert\NotBlank(),
                new Assert\Email(),
                new Assert\Callback(array(
                    "methods"   =>  array(function ($email, ExecutionContext $context) use ($app) {
                        if ($app["user"]->findByEmail($email)) {
                            $context->addViolation("Email already used");
                        }
                    }),
                )),
            ),
        ));
    }

    public function setDefaultOptions(OptionsResolverInterface $resolver)
    {
        parent::setDefaultOptions($resolver);
        $resolver->setRequired(array("app"));
    }

    public function getName()
    {
        return "register";
    }
}

ノート:

  • $appが注入されるので、依存性注入コンテナにアクセスできます
  • $app["user"]KnpRepositoryServiceProviderを介した私のユーザーテーブルです
  • $app["user"]->findByEmailnullまたはユーザーレコードを返します
于 2012-10-07T20:03:21.463 に答える