《PHP學(xué)習(xí):Zend Framework校驗(yàn)器Zend_Validate用法詳解》要點(diǎn):
本文介紹了PHP學(xué)習(xí):Zend Framework校驗(yàn)器Zend_Validate用法詳解,希望對您有用。如果有疑問,可以聯(lián)系我們。
本文實(shí)例講述了Zend Framework校驗(yàn)器Zend_Validate用法.分享給大家供大家參考,具體如下:PHP應(yīng)用
引言:PHP應(yīng)用
是對輸入內(nèi)容進(jìn)行檢查,并生成一個(gè)布爾結(jié)果來表明內(nèi)容是否被成功校驗(yàn)的機(jī)制.PHP應(yīng)用
如果isValid()方法返回False,子類的getMessage()方法將返回一個(gè)消息數(shù)組來解釋校驗(yàn)失敗的原因.PHP應(yīng)用
為了正確地返回消息與錯誤內(nèi)容,對于isValid()方法的每次調(diào)用,都需要清除前一個(gè)isValid()方法調(diào)用所導(dǎo)致的消息和錯誤.PHP應(yīng)用
案例:PHP應(yīng)用
<?php require_once 'Zend/Validate/EmailAddress.php'; function c_email($email) { $validator = new Zend_Validate_EmailAddress(); if($validator->isValid($email)){ echo "輸入的E-mail地址:"; echo $email."有效!<p>"; }else{ echo "輸入的E-mail地址:"; echo $email."無效!"; echo "失敗消息為:<p>"; foreach($validator->getMessages() as $message){ echo $message."<p>"; } foreach($validator->getErrors() as $error){ echo $error."<p>"; } } } $e_m1 = "abc@123.com"; $e_m2 = "abc#123.com"; c_email($e_m1); c_email($e_m2);
結(jié)果:PHP應(yīng)用
輸入的E-mail地址:abc@123.com有效!
輸入的E-mail地址:abc#123.com無效!失敗消息為:
'abc#123.com' is not a valid email address in the basic format local-part@hostname
emailAddressInvalidFormatPHP應(yīng)用
說明:PHP應(yīng)用
在引入類之后,定義一個(gè)驗(yàn)證函數(shù),在函數(shù)中實(shí)例化類.用isValid()方法來進(jìn)行驗(yàn)證,不同的子類驗(yàn)證器驗(yàn)證的內(nèi)容是不一樣的.
同時(shí)通過getMessages()方法和getErrors()方法來.PHP應(yīng)用
源碼賞析:PHP應(yīng)用
public function isValid($value) { if (!is_string($value)) { $this->_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; }
解析:PHP應(yīng)用
這是主要的驗(yàn)證函數(shù)內(nèi)容,分成了多種情況進(jìn)行驗(yàn)證,有是否字符串,有是否符合郵箱規(guī)則,有長度是否符合,最終都符合才返回true.PHP應(yīng)用
更多關(guān)于zend相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《Zend FrameWork框架入門教程》、《php優(yōu)秀開發(fā)框架總結(jié)》、《Yii框架入門及常用技巧總結(jié)》、《ThinkPHP入門教程》、《php面向?qū)ο蟪绦蛟O(shè)計(jì)入門教程》、《php+mysql數(shù)據(jù)庫操作入門教程》及《php常見數(shù)據(jù)庫操作技巧匯總》PHP應(yīng)用
希望本文所述對大家基于Zend Framework框架的PHP程序設(shè)計(jì)有所幫助.PHP應(yīng)用
轉(zhuǎn)載請注明本頁網(wǎng)址:
http://www.snjht.com/jiaocheng/2454.html