自定义Zend Framework 2电子邮件字段验证器错误消息


Customizing Zend Framework 2 Email Field Validator Error Messages

我有一个输入过滤器,其电子邮件字段的验证器配置如下所示;

'validators' => array(
    array (
        'name' => 'EmailAddress',
        'options' => array(
            'messages' => array(
                'emailAddressInvalidFormat' => "Email address doesn't appear to be valid.",
            )
        ),
    ),
    array (
        'name' => 'NotEmpty',
            'options' => array(
                'messages' => array(
                    'isEmpty' => 'Email address is required',
                )
            ),
        ),
    ),
),

它是有效的,这一部分很好,但我会永远被这里的业务部门嘲笑的是,如果我发布一个应用程序,向用户吐出这个错误消息:

输入与模式不匹配

'/^[a-zA-Z0-9.!#$%&'+/=?^_`{|}~]+@[a-zA-APP-GW-9-]+(?:.[a-zA-Z09-]+)$/'

有一部奇怪的书呆子喜剧埋在里面(是的,我意识到这是准确的,但是,罗夫)。

我有两个问题要问这里善良的灵魂:

如何自定义该错误消息我似乎找不到合适的钥匙,因为我很容易就找到了'emailAddressInvalidFormat'

此外,是否可以将所有错误汇总为一个我的意思是。而不是发布:

"你的电子邮件模式刚刚离开大楼&你的电子邮件不能空白&您的电子邮件似乎无效"

我可以把"单一失败"的消息放进电子邮件吗?

"嘿,伙计,检查一下你的电子邮件,有些不对劲!"

一如既往地感谢你的帮助。

更新

在这里投票支持这个bughttps://github.com/zendframework/zend-validator/issues/41

在ZF2:中尝试自定义邮件验证

 'validators' => array(
                array( 
                    'name' => 'EmailAddress',
                    'options' => array( 
                        'messages' => array(
                        'Zend'Validator'EmailAddress::INVALID_FORMAT => '"Hey bud, check your email, something ain''t right!"' 
                        )             
                    )                   
                )             
            )         

根据ZF2,电子邮件地址验证为:

  $this->add(array(
        'name'       => 'email',
        'required'   => true,
        'validators' => array(
            array(
                'name' => 'EmailAddress',
                'options' => array(
                    'message' => array(
                        'Zend'Validator'EmailAddress::INVALID =>   "Invalid type given. String expected",
                        'Zend'Validator'EmailAddress::INVALID_FORMAT     =>"The input is not a valid email address. Use the basic format local-part@hostname",
                        'Zend'Validator'EmailAddress::INVALID_HOSTNAME   =>"'%hostname%' is not a valid hostname for the email address",
                        'Zend'Validator'EmailAddress::INVALID_MX_RECORD  =>"'%hostname%' does not appear to have any valid MX or A records for the email address" ,
                        'Zend'Validator'EmailAddress::INVALID_SEGMENT    =>"'%hostname%' is not in a routable network segment. The email address should not be resolved from public network",
                        'Zend'Validator'EmailAddress::DOT_ATOM           =>"'%localPart%' can not be matched against dot-atom format" ,
                        'Zend'Validator'EmailAddress::QUOTED_STRING      =>"'%localPart%' can not be matched against quoted-string format",
                        'Zend'Validator'EmailAddress::INVALID_LOCAL_PART =>"'%localPart%' is not a valid local part for the email address" ,
                        'Zend'Validator'EmailAddress::LENGTH_EXCEEDED    =>"The input exceeds the allowed length",
                        ),
                ),
            ),
        ),
    ));

如上所述,额外的验证可以是Regex,如果电子邮件地址用于登录,我也有NoObjectExists

array(
    'name'      => 'DoctrineModule'Validator'NoObjectExists',
    'options' => array(
        'object_repository' => $sm->get('doctrine.entitymanager.orm_default')->getRepository('MyMudole'Entity'User'),
        'fields'            => 'email',
        'message'=>'This email is associated with another user! Please use another email',
    ),
),

"输入与模式不匹配"消息实际上似乎是Zend'Validator'Regex::NOT_MATCH,而不是Zend'Validator'EmailAddress类。

从您的代码中,还不清楚在哪里以及是否使用Regex验证器。我认为EmailAddress内部不使用Regex

如果您想自定义Regex消息,它可能看起来像这样:

array (
    'name' => 'Regex',
    'options' => array(
        'messages' => array(
            'regexNotMatch' => "Not so nerdy message here.",
        )
    ),
),

不可能只指定一条消息,但它应该也能工作:

    $message = sprintf(
        $this->getTranslate()->translate(
            '%s filled is not a valid e-mail address, please inform a valid in the field.'
        ),
        $entity
    );
    return array(
        'name' => 'EmailAddress',
        'options' => array(
            'messages' => array(
                'Zend'Validator'EmailAddress::INVALID            => $message,
                'Zend'Validator'EmailAddress::INVALID_FORMAT     => $message,
                'Zend'Validator'EmailAddress::INVALID_HOSTNAME   => $message,
                'Zend'Validator'EmailAddress::INVALID_MX_RECORD  => $message,
                'Zend'Validator'EmailAddress::INVALID_SEGMENT    => $message,
                'Zend'Validator'EmailAddress::DOT_ATOM           => $message,
                'Zend'Validator'EmailAddress::QUOTED_STRING      => $message,
                'Zend'Validator'EmailAddress::INVALID_LOCAL_PART => $message,
                'Zend'Validator'EmailAddress::LENGTH_EXCEEDED    => $message,
            ),
        ),
        'break_chain_on_failure' => true
    );