首頁 >後端開發 >php教程 >Zend Framework校驗器Zend_Validate的用法解析

Zend Framework校驗器Zend_Validate的用法解析

不言
不言原創
2018-06-09 14:51:072476瀏覽

這篇文章主要介紹了Zend Framework校驗器Zend_Validate用法,結合實例形式分析了校驗器Zend_Validate的功能、使用技巧與相關注意事項,需要的朋友可以參考下

本文實例講述了Zend Framework校驗器Zend_Validate用法。分享給大家供大家參考,具體如下:

引言:

是對輸入內容進行檢查,並產生一個布林結果來表明內容是否被成功校驗的機制。

如果isValid()方法傳回False,子類別的getMessage()方法會傳回一個訊息陣列來解釋校驗失敗的原因。

為了正確地傳回訊息與錯誤內容,對於isValid()方法的每次調用,都需要清除前一個isValid()方法呼叫所導致的訊息和錯誤。

案例:

<?php
require_once &#39;Zend/Validate/EmailAddress.php&#39;;
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);

結果:

輸入的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
emailAddressInvalidFormat

說明:

在引入類別之後,定義一個驗證函數,在函數中實例化類別。用isValid()方法來進行驗證,不同的子類別驗證器驗證的內容是不一樣的。
同時透過getMessages()方法和getErrors()方法來。

原始碼賞析:

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 &#39;..&#39;
    if ((strpos($value, &#39;..&#39;) !== false) or
      (!preg_match(&#39;/^(.+)@([^@]+)$/&#39;, $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[&#39;domain&#39;]) {
      $hostname = $this->_validateHostnamePart();
    }
    $local = $this->_validateLocalPart();
    // If both parts valid, return true
    if ($local && $length) {
      if (($this->_options[&#39;domain&#39;] && $hostname) || !$this->_options[&#39;domain&#39;]) {
        return true;
      }
    }
    return false;
}

#解析:

這是主要的驗證函數內容,分成了多種情況進行驗證,有是否字串,有是否符合郵箱規則,有長度是否符合,最終都符合才回傳true。

以上就是本文的全部內容,希望對大家的學習有所幫助,更多相關內容請關注PHP中文網!

相關推薦:

Zend Framework中Zend_View元件的用法解析

#########################

以上是Zend Framework校驗器Zend_Validate的用法解析的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn