亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Zend Framework常用校驗器的示例分析

發布時間:2021-09-02 09:31:45 來源:億速云 閱讀:101 作者:小新 欄目:開發技術

這篇文章給大家分享的是有關Zend Framework常用校驗器的示例分析的內容。小編覺得挺實用的,因此分享給大家做個參考,一起跟隨小編過來看看吧。

具體如下:

Date日期校驗器

代碼:

<?php
require_once 'Zend/Validate/Date.php';
function c_date($date){
  $validator = new Zend_Validate_Date();
  if($validator->isValid($date)){
    echo "輸入的日期格式:";
    echo $date."有效!<p>";
  }else{
    echo "輸入的日期格式:";
    echo $date."無效!<p>";
  }
}
$date1 = "2008-02-15";
$date2 = "2008-02-31";
$date3 = "02-15-2008";
c_date($date1);
c_date($date2);
c_date($date3);

結果:

輸入的日期格式:2008-02-15有效!

輸入的日期格式:2008-02-31無效!

輸入的日期格式:02-15-2008無效!

點評:源碼解析

public function isValid($value)
{
    if (!is_string($value) && !is_int($value) && !is_float($value) &&
      !is_array($value) && !($value instanceof Zend_Date)) {
      $this->_error(self::INVALID);
      return false;
    }
    $this->_setValue($value);
    if (($this->_format !== null) || ($this->_locale !== null) || is_array($value) ||
       $value instanceof Zend_Date) {
      require_once 'Zend/Date.php';
      if (!Zend_Date::isDate($value, $this->_format, $this->_locale)) {
        if ($this->_checkFormat($value) === false) {
          $this->_error(self::FALSEFORMAT);
        } else {
          $this->_error(self::INVALID_DATE);
        }
        return false;
      }
    } else {
      if (!preg_match('/^\d{4}-\d{2}-\d{2}$/', $value)) {
        $this->_format = 'yyyy-MM-dd';
        $this->_error(self::FALSEFORMAT);
        $this->_format = null;
        return false;
      }
      list($year, $month, $day) = sscanf($value, '%d-%d-%d');
      if (!checkdate($month, $day, $year)) {
        $this->_error(self::INVALID_DATE);
        return false;
      }
    }
    return true;
}

InArray數組包含校驗器

如果內容包含在數組中將返回True,否則返回False。

代碼:

<?php
require_once 'Zend/Validate/InArray.php';
function c_array($n){
  $temp = array("北京","上海","天津","重慶");
  $validator = new Zend_Validate_InArray($temp);
  if($validator->isValid($n)){
    echo "指定的內容:";
    echo $n.",存在于指定數組中!<p>";
  }else{
    echo "指定的內容:";
    echo $n.",不存在于指定數組中!<p>";
  }
}
$city1 = "北京";
$city2 = "重慶";
$city3 = "鄭州";
c_array($city1);
c_array($city2);
c_array($city3);

結果:

指定的內容:北京,存在于指定數組中!

指定的內容:重慶,存在于指定數組中!

指定的內容:鄭州,不存在于指定數組中!

Regex正則匹配校驗器

通過使用正則表達式,再加上合理使用本校驗器,幾乎可以實現所有的校驗規則。

代碼:

<?php
require_once "Zend/Validate.php";
function c_rege($v){
  $pattern = array("/ab{2,}/");
  if(Zend_Validate::is($v,"Regex",$pattern)){
    echo "<font color=\"#006600\">指定的內容:";
    echo $v."<p>符合定義的正規規則!</font>";
    echo "<p>";
  }else{
    echo "<font color=\"#ff0000\">指定的內容:";
    echo $v."<p>不符合定義的正規規則!</font>";
    echo "<p>";
  }
}
$temp1 = "ab";
$temp2 = "abb";
$temp3 = "abbb";
c_rege($temp1);
c_rege($temp2);
c_rege($temp3);

結果:

指定的內容:ab

不符合定義的正規規則!

指定的內容:abb

符合定義的正規規則!

指定的內容:abbb

符合定義的正規規則!

點評:

public function __construct($pattern)
{
    if ($pattern instanceof Zend_Config) {
      $pattern = $pattern->toArray();
    }
    if (is_array($pattern)) {
      if (array_key_exists('pattern', $pattern)) {
        $pattern = $pattern['pattern'];
      } else {
        require_once 'Zend/Validate/Exception.php';
        throw new Zend_Validate_Exception("Missing option 'pattern'");
      }
    }
    $this->setPattern($pattern);
}

構造函數初始化私有屬性,

public function isValid($value)
{
    if (!is_string($value) && !is_int($value) && !is_float($value)) {
      $this->_error(self::INVALID);
      return false;
    }
    $this->_setValue($value);
    $status = @preg_match($this->_pattern, $value);
    if (false === $status) {
      $this->_error(self::ERROROUS);
      return false;
    }
    if (!$status) {
      $this->_error(self::NOT_MATCH);
      return false;
    }
    return true;
}

進行驗證工作。

自定義校驗器編寫

繼承Zend_Validate_Interface接口實現用戶自定義校驗器。

代碼案例,功能判斷指定數值是否為3的倍數。

接口代碼:

<?php
/**
 * Zend Framework
 *
 * LICENSE
 *
 * This source file is subject to the new BSD license that is bundled
 * with this package in the file LICENSE.txt.
 * It is also available through the world-wide-web at this URL:
 * http://framework.zend.com/license/new-bsd
 * If you did not receive a copy of the license and are unable to
 * obtain it through the world-wide-web, please send an email
 * to license@zend.com so we can send you a copy immediately.
 *
 * @category  Zend
 * @package  Zend_Validate
 * @copyright Copyright (c) 2005-2012 Zend Technologies USA Inc. (http://www.zend.com)
 * @license  http://framework.zend.com/license/new-bsd   New BSD License
 * @version  $Id: Interface.php 24593 2012-01-05 20:35:02Z matthew $
 */
/**
 * @category  Zend
 * @package  Zend_Validate
 * @copyright Copyright (c) 2005-2012 Zend Technologies USA Inc. (http://www.zend.com)
 * @license  http://framework.zend.com/license/new-bsd   New BSD License
 */
interface Zend_Validate_Interface
{
  /**
   * Returns true if and only if $value meets the validation requirements
   *
   * If $value fails validation, then this method returns false, and
   * getMessages() will return an array of messages that explain why the
   * validation failed.
   *
   * @param mixed $value
   * @return boolean
   * @throws Zend_Validate_Exception If validation of $value is impossible
   */
  public function isValid($value);
  /**
   * Returns an array of messages that explain why the most recent isValid()
   * call returned false. The array keys are validation failure message identifiers,
   * and the array values are the corresponding human-readable message strings.
   *
   * If isValid() was never called or if the most recent isValid() call
   * returned true, then this method returns an empty array.
   *
   * @return array
   */
  public function getMessages();
}

要實現其中的兩個方法,一個是isValid(),一個是getMessages()

實現代碼:

<?php
require_once "Zend/Validate/Interface.php";
class MyValidator implements Zend_Validate_Interface{
  protected $_messages = array();
  public function isValid($value){
    $this->_messages = array();
    $requirement = !($value%3);
    if(!$requirement){
      $this->_messages[] = "'$value'不能被3整除";
      return false;
    }
    return true;
  }
  public function getMessages(){
    return $this->_messages;
  }
}
function c_n_3($n){
  $validator = new MyValidator();
  if($validator->isValid($n)){
    echo "指定的數值:";
    echo $n.",是3的倍數!<p>";
  }else{
    echo "指定的數值:";
    echo $n.",不是3的倍數!<p>";
    echo "失敗的消息為:<p>";
    foreach ($validator->getMessages() as $message) {
      echo "$message<p>";
    }
  }
}
$num1 = 5;
$num2 = 6;
$num3 = 8;
c_n_3($num1);
c_n_3($num2);
c_n_3($num3);

結果:

指定的數值:5,不是3的倍數!

失敗的消息為:

'5'不能被3整除

指定的數值:6,是3的倍數!

指定的數值:8,不是3的倍數!

失敗的消息為:

'8'不能被3整除

點評:

這里通過isValid()方法來設置屬性信息,通過getMessages()方法來獲取錯誤消息。錯誤消息是一個數組,通過foreach()方法來遍歷讀取。

感謝各位的閱讀!關于“Zend Framework常用校驗器的示例分析”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,讓大家可以學到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

泾阳县| 仪陇县| 饶河县| 越西县| 安阳市| 公安县| 涡阳县| 石泉县| 新泰市| 安康市| 莱州市| 莎车县| 云和县| 天峨县| 包头市| 荣昌县| 富民县| 英吉沙县| 通城县| 平塘县| 米泉市| 隆林| 周至县| 额敏县| 罗江县| 应城市| 祁阳县| 全南县| 邯郸县| 安康市| 上栗县| 仙游县| 读书| 西平县| 仙居县| 玉树县| 德兴市| 横山县| 邢台县| 汉寿县| 麟游县|