Zend Framework校验器Zend_Validate用法详解
本文实例讲述了Zend Framework校验器Zend_Validate用法。分享给大家供大家参考,具体如下: 引言:是对输入内容进行检查,并生成一个布尔结果来表明内容是否被成功校验的机制。 如果isValid()方法返回False,子类的getMessage()方法将返回一个消息数组来解释校验失败的原因。 为了正确地返回消息与错误内容,对于isValid()方法的每次调用,都需要清除前一个isValid()方法调用所导致的消息和错误。 案例: isValid($email)){
echo "输入的E-mail地址:";
echo $email."有效! "; }else{ echo "输入的E-mail地址:"; echo $email."无效!"; echo "失败消息为: "; foreach($validator->getMessages() as $message){ echo $message." "; } foreach($validator->getErrors() as $error){ echo $error." "; } } } $e_m1 = "abc@123.com"; $e_m2 = "abc#123.com"; c_email($e_m1); c_email($e_m2); 结果:
说明:在引入类之后,定义一个验证函数,在函数中实例化类。用isValid()方法来进行验证,不同的子类验证器验证的内容是不一样的。 同时通过getMessages()方法和getErrors()方法来。 源码赏析: _error(self::INVALID); return false; } $matches = array(); $length = true; $this->_setValue($value); // Split email address up and disallow '..' if ((strpos($value,'..') !== false) or (!preg_match('/^(.+)@([^@]+)$/',$value,$matches))) { $this->_error(self::INVALID_FORMAT); return false; } $this->_localPart = $matches[1]; $this->_hostname = $matches[2]; if ((strlen($this->_localPart) > 64) || (strlen($this->_hostname) > 255)) { $length = false; $this->_error(self::LENGTH_EXCEEDED); } // Match hostname part if ($this->_options['domain']) { $hostname = $this->_validateHostnamePart(); } $local = $this->_validateLocalPart(); // If both parts valid,return true if ($local && $length) { if (($this->_options['domain'] && $hostname) || !$this->_options['domain']) { return true; } } return false; }解析:这是主要的验证函数内容,分成了多种情况进行验证,有是否字符串,有是否符合邮箱规则,有长度是否符合,最终都符合才返回true。 更多关于zend相关内容感兴趣的读者可查看本站专题:《》、《》、《》、《》、《》、《》及《》 希望本文所述对大家基于Zend Framework框架的PHP程序设计有所帮助。 (编辑:甘南站长网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |