web-dev-qa-db-ja.com

Symfony2-コントローラーでメールアドレスを検証する方法

Symfonyにはフォームで使用できるメールバリデーターがあります: http://symfony.com/doc/current/reference/constraints/Email.html

私の質問は次のとおりです。電子メールアドレスを検証するために、このコントローラーをコントローラーで使用するにはどうすればよいですか。

これはusereにPHP preg_matchを使用することで可能になりますが、私の質問は、すでに電子メールバリデーターに組み込まれているSymfonyを使用する可能性があるかどうかです。

前もって感謝します。

22
Miloš

validateValueValidator サービスのメソッドを使用して

use Symfony\Component\Validator\Constraints\Email as EmailConstraint;
// ...

public function customAction()
{
    $email = 'value_to_validate';
    // ...

    $emailConstraint = new EmailConstraint();
    $emailConstraint->message = 'Your customized error message';

    $errors = $this->get('validator')->validateValue(
        $email,
        $emailConstraint 
    );

    // $errors is then empty if your email address is valid
    // it contains validation error message in case your email address is not valid
    // ...
}
// ...
52
Ahmed Siouani

フォーム以外の電子メールアドレス(1つまたは複数)の検証に関する投稿を書いた

http://konradpodgorski.com/blog/2013/10/29/how-to-validate-emails-outside-of-form-with-symfony-validator-component/

また、Email Constraintに対して検証し、NotBlankを忘れる一般的なバグもカバーします。

/**
 * Validates a single email address (or an array of email addresses)
 *
 * @param array|string $emails
 *
 * @return array
 */
public function validateEmails($emails){

    $errors = array();
    $emails = is_array($emails) ? $emails : array($emails);

    $validator = $this->container->get('validator');

    $constraints = array(
        new \Symfony\Component\Validator\Constraints\Email(),
        new \Symfony\Component\Validator\Constraints\NotBlank()
    );

    foreach ($emails as $email) {

        $error = $validator->validateValue($email, $constraints);

        if (count($error) > 0) {
            $errors[] = $error;
        }
    }

    return $errors;
}

これが役立つことを願っています

15

コントローラー自体でフォームを作成していて、アクションで電子メールを検証する場合、コードは次のようになります。

// add this above your class
use Symfony\Component\Validator\Constraints\Email;

public function saveAction(Request $request) 
{
    $form = $this->createFormBuilder()
        ->add('email', 'email')
        ->add('siteUrl', 'url')
        ->getForm();

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

        // the data is an *array* containing email and siteUrl
        $data = $form->getData();

        // do something with the data
        $email = $data['email'];

        $emailConstraint = new Email();
        $emailConstraint->message = 'Invalid email address';

        $errorList = $this->get('validator')->validateValue($email, $emailConstraint);
        if (count($errorList) == 0) {
            $data = array('success' => true);
        } else {
            $data = array('success' => false, 'error' => $errorList[0]->getMessage());
        }
   }

   return $this->render('AcmeDemoBundle:Default:update.html.twig', array(
       'form' => $form->createView()
   ));
}

私も新しくて、それを学んでいます、どんな提案でも感謝されます...

10
Amit Malakar

「constraints」キーを使用してFormBuilderインスタンスで検証できることを誰も言及していないのはなぜですか?まず、ドキュメントを読んでください クラスなしのフォームの使用

'constraints' =>[
    new Assert\Email([
        'message'=>'This is not the corect email format'
    ]),
    new Assert\NotBlank([
        'message' => 'This field can not be blank'
    ])
],

Symfony 3.1で正常に動作します

例:

namespace SomeBundle\Controller;

use Symfony\Component\HttpFoundation\Request;
use Symfony\Component\Form\Extension\Core\Type;
use Symfony\Component\Validator\Constraints as Assert;

class DefaultController extends Controller
{

    /**
     * @Route("kontakt", name="_kontakt")
     */
    public function userKontaktAction(Request $request) // access for all
    {

        $default = array('message' => 'Default input value');
        $form = $this->createFormBuilder($default)
        ->add('name', Type\TextType::class,[
            'label' => 'Nazwa firmy',
        ])
        ->add('email', Type\EmailType::class,[
            'label' => 'Email',
            'constraints' =>[
                new Assert\Email([
                    'message'=>'This is not the corect email format'
                ]),
                new Assert\NotBlank([
                    'message' => 'This field can not be blank'
                ])
            ],
        ])
        ->add('phone', Type\TextType::class,[
            'label' => 'Telefon',
        ])
        ->add('message', Type\TextareaType::class,[
            'label' => 'Wiadomość',
            'attr' => [
                'placeholder' => 'Napisz do nas ... '
            ],
        ])
        ->add('send', Type\SubmitType::class,[
            'label' => 'Wyślij',
        ])
        ->getForm();

        $form->handleRequest($request);

        if ($form->isValid()) {
            // data is an array with "name", "email", and "message" keys
            $data = $form->getData();
            // send email
            // redirect to prevent resubmision
            var_dump($data);
        }

        return $this->render('SomeBundle:Default:userKontakt.html.twig', [
            'form' => $form->createView()
        ]);
    }

}

結果: enter image description here

利用可能な検証タイプに関するドキュメントを参照してください。 http://api.symfony.com/3.1/Symfony/Component/Validator/Constraints.html

メッセージ以外の使用可能なキーを確認するには、次のドキュメントにアクセスしてください。

http://symfony.com/doc/current/reference/constraints/Email.html

または次の場所に移動します:

YourProject\vendor\symfony\symfony\src\Symfony\Component\Validator\Constraints\Email.php

そこから、他に利用可能なものを確認できます。

public $message = 'This value is not a valid email address.';

public $checkMX = false;

public $checkHost = false;

public $strict; "

また、コントローラー内でフォームを作成および検証しましたが、これはベストプラクティスではなく、アプリケーションで他の場所で再利用することのないフォームにのみ使用してください。

ベストプラクティスは、YourBundle/Formの下の個別のディレクトリにフォームを作成することです。すべてのコードを新しいContactType.phpクラスに移動します。 (FormBuilderクラスをインポートすることを忘れないでください。コントローラを拡張せず、「$ this」を介してこのクラスにアクセスできません)

[ContactTypeクラス内:]

namespace AdminBundle\Form;

use Symfony\Component\Form\AbstractType;
use Symfony\Component\Form\FormBuilderInterface;
use Symfony\Component\Form\Extension\Core\Type;
use Symfony\Component\Validator\Constraints as Assert;

[コントローラーの内部:]

use YourBundle/Form/ContactType;
// use ...

//...
$presetData = []; //... preset form data here if you want to
$this->createForm('AdminBundle\Form\FormContactType', $presetData) // instead of 'createFormBuilder'
->getForm();
// render view and pass it to twig templet...
// or send the email/save data to database and redirect the form
7
DevWL

Symfony 3の私のソリューションは次のとおりです。

use Symfony\Component\Validator\Constraints\Email as EmailConstraint;

$email = '[email protected]';
// ... in the action then call
$emailConstraint = new EmailConstraint();

$errors = $this->get('validator')->validate(
    $email,
    $emailConstraint
);

$mailInvalid = count($errors) > 0;
1
totas