3

こんにちは、zf2 フォームの日付フィールドを検証したいと思います。「フォーマット」オプションを設定して、必要なフォーマットを取得します。しかし、検証するたびにエラーが発生します。バリデータは次のようになります。

            $inputFilter->add($factory->createInput(array(
            'name' => 'user_data_birth',
            'required' => false,
            'validators' => array(
                array(
                'name' => 'Date',
                'options' => array(
                    'format' => 'd.m.Y',
                    'locale' => 'de',
                    'messages' => array(
                        \Zend\Validator\Date::INVALID => 'Das scheint kein gültiges Datum zu sein.',
                        \Zend\Validator\Date::INVALID_DATE => 'Das scheint kein gültiges Datum zu sein. (Invalid Date)',
                        \Zend\Validator\Date::FALSEFORMAT => 'Das Datum ist nicht im richtigen Format.',
                        ),
                    ),
                ),
                array(
                    'name' => 'NotEmpty',
                    'options' => array(
                    'messages' => array(
                        \Zend\Validator\NotEmpty::IS_EMPTY => 'Bitte geben Sie das Datum an'
                        ),
                    ),
                )
            ),
        )));

しかし、日付の形式が間違っているというエラーが毎回発生します。

4

4 に答える 4

14

次のようにコールバック関数を使用して、開始日が終了日の検証よりも前でなければならないという問題を解決できます。

          $inputFilter->add($factory->createInput(array(
                'name' => 'end_date',
                'required' => true,                 
                'filters' => array(
                        array('name' => 'StripTags'),
                        array('name' => 'StringTrim'),
                ),
                'validators' => array(
                    array(
                        'name' => 'Callback',
                        'options' => array(
                            'messages' => array(
                                    \Zend\Validator\Callback::INVALID_VALUE => 'The end date should be greater than start date',
                            ),
                            'callback' => function($value, $context = array()) {                                    
                                $startDate = \DateTime::createFromFormat('d-m-Y', $context['start_date']);
                                $endDate = \DateTime::createFromFormat('d-m-Y', $value);
                                return $endDate >= $startDate;
                            },
                        ),
                    ),                          
                ),
        )));

上記のコードを使用して、問題を解決しました。これが役立つことを願っています。

于 2013-10-09T04:17:57.787 に答える
0

これを 1 つのフォームでのみ使用する必要がある場合、CallBack 関数は非常に便利な方法です。ほとんどの場合、これを複数の場所で使用する必要があります。私はいくつかの調査を行い、このカスタムバリデータを作成しました。このバリデータは 2 つの文字列を比較します。これらの文字列が異なる必要があるか、同じである必要があるかを確認する別のトリックを追加しました。

パスワードを変更する場合。次に、古いパスワードと新しいパスワードを同時に異なるものにすると同時に、新しいパスワードの検証を新しいパスワードと同じにする必要があります。このバリデーターは、異なるパラメーターを「true」または「false」に変更するだけで、両方のケースに使用できます。

Form Fields
user_password
new_user_password
new_user_password_verify

Application\src\Application\Validator に新しいバリデータ StringCompare.php を作成します。

<?php

namespace Application\Validator;

class StringCompare extends \Zend\Validator\AbstractValidator {

    const SAME = 'same';
    const DIFFERENT = 'different';

    protected $messageTemplates = array(
        self::SAME => "Both the words are the same",
        self::DIFFERENT => "Both the words are different",
    );

    protected $messageVariables = array(
        'compareWith' => array( 'options' => 'compareWith' ),
        'different' => array( 'options' => 'different' ),
    );

    protected $options = array(
        'compareWith' => "",
        'different' => true,
        'encoding' => 'UTF-8',
    );

    public function __construct( $options = array( ) ) {
        parent::__construct( $options );
    }

    public function getCompareWith( ) {
        return $this->options[ 'compareWith' ];
    }

    public function getDifferent( ) {
        return $this->options[ 'different' ];
    }

    public function isValid( $value, $context=array( ) ) {

        $compareWith = $this->getCompareWith( );
        $different = $this->getDifferent( );

        $returnValue =  $value == $context[$compareWith];
        if ( $different ) {
            $returnValue = !$returnValue;
       if ( !$returnValue ) {
          $this->error( self::SAME );
           }
        } else {
        if ( !$returnValue ) {
        $this->error( self::DIFFERENT );
        }
    }
        return $returnValue;


    }

}

フォーム フィルターに次を追加します。

$this->add ( array (
    'name'  => 'new_user_password',
    'required' => true,
    'filters' => array (
        array ( 
            'name' => 'StringTrim',
        ),
    ),
    'validators' => array (
        array (
            'name' => 'StringLength',
            'options' => array (
                'min' => 8,
                'max' => 20,
            )
        ),
        array (
            'name' => 'Application\Validator\StringCompare',
            'options' => array (
                'compareWith' => 'user_password',
                'different' => true,
            ),
        ),
    )
) );

コントローラーでフォームの検証を実行すると、完了です。different = 'true' を使用すると、検証ルーチンは 2 つの値が異なることを確認し、'false' を使用すると、文字列が同じであることを確認します。

于 2014-05-17T08:54:26.490 に答える