程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> 網頁編程 >> PHP編程 >> PHP綜合 >> Zend Framework過濾器Zend_Filter用法詳解

Zend Framework過濾器Zend_Filter用法詳解

編輯:PHP綜合

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

引言:過濾器是對輸入內容進行過濾,清除其中不符合過濾規則的內容,並將其余內容返回的過程。

Zend中有個Zend_Filter組件用來實現過濾的功能。其中有個Zend_Filter_Interface子類,該子類為實現一般過濾器提供了接口。

要實現過濾器類,需要實現該接口中一個名為filter()的方法。

下面通過實例來演示如何使用Zend_Filter中定義的過濾器,該例演示如何實現字母轉小寫的功能。

代碼:

<?php
require_once 'Zend/Filter/StringToLower.php';  //加載子類
$filter = new Zend_Filter_StringToLower;    //實例化對象
$temp1 = "ABCDefGH";              //定義待過濾內容
$temp2 = "我愛Nan Jing";
echo "內容:".$temp1."<p>經過濾後為:";
echo $filter->filter($temp1);
echo "<p>";
echo "內容:".$temp2."<p>經過濾後為:";
echo $filter->filter($temp2);

結果:

內容:ABCDefGH
經過濾後為:abcdefgh
內容:我愛Nan Jing
經過濾後為:我愛nan jing

為什麼如此神奇呢?不禁讓我想探索一下其內部的構造!下面來研讀一下其內部的工作原理。

class Zend_Filter_StringToLower implements Zend_Filter_Interface
{
  /**
   * Encoding for the input string
   *
   * @var string
   */
  protected $_encoding = null;
  /**
   * Constructor
   *
   * @param string|array|Zend_Config $options OPTIONAL
   */
  public function __construct($options = null)
  {
    if ($options instanceof Zend_Config) {
      $options = $options->toArray();
    } else if (!is_array($options)) {
      $options = func_get_args();
      $temp  = array();
      if (!empty($options)) {
        $temp['encoding'] = array_shift($options);
      }
      $options = $temp;
    }
    if (!array_key_exists('encoding', $options) && function_exists('mb_internal_encoding')) {
      $options['encoding'] = mb_internal_encoding();
    }
    if (array_key_exists('encoding', $options)) {
      $this->setEncoding($options['encoding']);
    }
  }
  /**
   * Returns the set encoding
   *
   * @return string
   */
  public function getEncoding()
  {
    return $this->_encoding;
  }
  /**
   * Set the input encoding for the given string
   *
   * @param string $encoding
   * @return Zend_Filter_StringToLower Provides a fluent interface
   * @throws Zend_Filter_Exception
   */
  public function setEncoding($encoding = null)
  {
    if ($encoding !== null) {
      if (!function_exists('mb_strtolower')) {
        require_once 'Zend/Filter/Exception.php';
        throw new Zend_Filter_Exception('mbstring is required for this feature');
      }
      $encoding = (string) $encoding;
      if (!in_array(strtolower($encoding), array_map('strtolower', mb_list_encodings()))) {
        require_once 'Zend/Filter/Exception.php';
        throw new Zend_Filter_Exception("The given encoding '$encoding' is not supported by mbstring");
      }
    }
    $this->_encoding = $encoding;
    return $this;
  }
  /**
   * Defined by Zend_Filter_Interface
   *
   * Returns the string $value, converting characters to lowercase as necessary
   *
   * @param string $value
   * @return string
   */
  public function filter($value)
  {
    if ($this->_encoding !== null) {
      return mb_strtolower((string) $value, $this->_encoding);
    }
    return strtolower((string) $value);
  }
}

研讀:

源代碼意思大概是先實現Zend_Filter_Interface接口。

定義一個私有變量$_encoding,初始值為null,一般私有變量都是以_下劃線開頭。

然後通過構造函數進行初始化工作,設置encoding。

至於這個encoing屬性是作何用的,我就不大清楚了,反正為了它,源碼寫了不少代碼。

類中有三個方法,一個是setEncoding,一個是getEncoding,一個主要功能的filter。有兩個方法都是為了encoding來寫的。

在構造函數中使用setEncoding方法直接用$this->setEncoding()就可。就可以把私有屬性設置好值了。

然後根據私有屬性的內容來選擇使用什麼方法來使得字母變小寫。

我去,這個類考慮的東西還真夠多的。其實核心代碼就那兩句,strtolower((string) $value)。

這個類很酷,我從來沒用過私有屬性。考慮問題也沒有作者那麼全面,各種驗證,各種情況考慮。比如,

從構造函數中就可以看出他考慮問題的全面性。

if ($options instanceof Zend_Config) {
  $options = $options->toArray();
} else if (!is_array($options)) {
  $options = func_get_args();
  $temp  = array();
  if (!empty($options)) {
    $temp['encoding'] = array_shift($options);
  }
  $options = $temp;
}
if (!array_key_exists('encoding', $options) && function_exists('mb_internal_encoding')) {
  $options['encoding'] = mb_internal_encoding();
}
if (array_key_exists('encoding', $options)) {
  $this->setEncoding($options['encoding']);
}

總的來說還是值得佩服的。

下面談談過濾器鏈,它的作用是將多個過濾器串聯起來配合使用。過濾器鏈就是多個過濾器的一個連接。在對指定的內容進行過濾時,

每個過濾器將按照其順序分別進行過濾或者轉化操作。當所有的過濾操作都執行完畢時,過濾器鏈返回最終的過濾結果。

聽起來蠻有趣的啊!

具體實現步驟是什麼呢?

首先要為類Zend_Filter實例化一個對象,然後通過該實例的addFilter()方法向過濾器鏈中添加過濾器。

下面通過示例演示如何使用過濾器鏈對數據進行多重過濾及轉化。

代碼:

<?php
require_once 'Zend/Filter.php';         //加載Zend_Filter類
require_once 'Zend/Filter/Alpha.php';      //加載Zend_Filter_Alpha子類
require_once 'Zend/Filter/StringToUpper.php';  //加載Zend_Filter_StringToUpper子類
$filterChain = new Zend_Filter();        //創建過濾器鏈
$filterChain ->addFilter(new Zend_Filter_Alpha(" "))
  ->addFilter(new Zend_Filter_StringToUpper());//向過濾器鏈中添加過濾器
$temp1 = "12345asdf67asdfasdf";
$temp2 = "#$%^!@fffff";
$temp3 = "Welcome to Bei Jing";
echo "內容:".$temp1."<p>經過過濾後為:";
echo $filterChain->filter($temp1);
echo "<p>";
echo "內容:".$temp2."<p>經過過濾後為:";
echo $filterChain->filter($temp2);
echo "<p>";
echo "內容:".$temp3."<p>經過過濾後為:";
echo $filterChain->filter($temp3);
echo "<p>";

結果:

內容:12345asdf67asdfasdf
經過過濾後為:ASDFASDFASDF
內容:#$%^!@fffff
經過過濾後為:FFFFF
內容:Welcome to Bei Jing
經過過濾後為:WELCOME TO BEI JING

分析:

這裡的Alpha很強大啊,過濾數字和特殊字符,連空格都能過濾。還好我初始化的時候加了個參數" ",才使得空格保留了下來。

為何如此神奇呢?

核心代碼就這一塊

public function filter($value)
{
    $whiteSpace = $this->allowWhiteSpace ? '\s' : '';
    if (!self::$_unicodeEnabled) {
      // POSIX named classes are not supported, use alternative a-zA-Z match
      $pattern = '/[^a-zA-Z' . $whiteSpace . ']/';
    } else if (self::$_meansEnglishAlphabet) {
      //The Alphabet means english alphabet.
      $pattern = '/[^a-zA-Z' . $whiteSpace . ']/u';
    } else {
      //The Alphabet means each language's alphabet.
      $pattern = '/[^\p{L}' . $whiteSpace . ']/u';
    }
    return preg_replace($pattern, '', (string) $value);
}

分析:這裡對內容進行過濾,如果不是字母或者空格,就統統去掉。用到的php方法是preg_replace。此外,還用到了正則表達式。[^a-zA-Z]表示除此之外的其他字符。

這裡的$whiteSpace成員屬性,是初始化的時候設置的,具體代碼如下:

public function __construct($allowWhiteSpace = false)
{
    if ($allowWhiteSpace instanceof Zend_Config) {
      $allowWhiteSpace = $allowWhiteSpace->toArray();
    } else if (is_array($allowWhiteSpace)) {
      if (array_key_exists('allowwhitespace', $allowWhiteSpace)) {
        $allowWhiteSpace = $allowWhiteSpace['allowwhitespace'];
      } else {
        $allowWhiteSpace = false;
      }
    }
    $this->allowWhiteSpace = (boolean) $allowWhiteSpace;
    if (null === self::$_unicodeEnabled) {
      self::$_unicodeEnabled = (@preg_match('/\pL/u', 'a')) ? true : false;
    }
    if (null === self::$_meansEnglishAlphabet) {
      $this->_locale = new Zend_Locale('auto');
      self::$_meansEnglishAlphabet = in_array($this->_locale->getLanguage(),
      array('ja', 'ko', 'zh')
      );
    }
}

此外,還有兩個方法來設置是否允許有空格和獲取是否設置了允許空格。

/**
* Returns the allowWhiteSpace option
*
* @return boolean
*/
public function getAllowWhiteSpace()
{
    return $this->allowWhiteSpace;
}
/**
* Sets the allowWhiteSpace option
*
* @param boolean $allowWhiteSpace
* @return Zend_Filter_Alpha Provides a fluent interface
*/
public function setAllowWhiteSpace($allowWhiteSpace)
{
    $this->allowWhiteSpace = (boolean) $allowWhiteSpace;
    return $this;
}

剖析完之後,我們似乎就更了解它的構造了,就是使用正則過濾而已。同時通過屬性allowWhiteSpace來控制是否過濾空格。

剛才介紹了兩種過濾器,一個是StringToUpper,一個是Alpha,下面再介紹其它的一些過濾器。

首先是Alnum,過濾非數字和非字母的內容,執行filter()方法,將返回純數字與字母的內容,它是Zend_Filter_Alpha(過濾非字母)與Zend_Filter_Digits(過濾非數值)的並集。

具體的例子就不舉了,都差不多。

我們來看看它內部的構造,

public function filter($value)
{
    $whiteSpace = $this->allowWhiteSpace ? '\s' : '';
    if (!self::$_unicodeEnabled) {
      // POSIX named classes are not supported, use alternative a-zA-Z0-9 match
      $pattern = '/[^a-zA-Z0-9' . $whiteSpace . ']/';
    } else if (self::$_meansEnglishAlphabet) {
      //The Alphabet means english alphabet.
      $pattern = '/[^a-zA-Z0-9' . $whiteSpace . ']/u';
    } else {
      //The Alphabet means each language's alphabet.
      $pattern = '/[^\p{L}\p{N}' . $whiteSpace . ']/u';
    }
    return preg_replace($pattern, '', (string) $value);
}

通過正則過濾除字母和數字之外的內容。

下面出場的是HtmlEntities HTML過濾器。

代碼:

<?php
require_once 'Zend/Filter/Htmlentities.php';
$filter = new Zend_Filter_HtmlEntities();
$temp1 = "<img src = './1.png' width='100px'>";
$temp2 = "<button>aaa</button>";
$temp3 = "<h1>Welcome to Bei Jing</h1>";
echo "內容:".$temp1."<p>經過過濾為:";
echo $filter->filter($temp1);
echo "<p>";
echo "內容:".$temp2."<p>經過過濾為:";
echo $filter->filter($temp2);
echo "<p>";
echo "內容:".$temp3."<p>經過過濾為:";
echo $filter->filter($temp3);
echo "<p>";

結果:

通過結果,我們看出它將html內容還原成原始代碼了。由於該過濾器是對函數htmlentities進行的封裝,所以遵循該函數的規則。即將“<”與“>”分別轉換為“<”與“>”,經過這樣的轉換,

相應的HTML內容就變成了以其原始格式顯示的字符串。

更多關於zend相關內容感興趣的讀者可查看本站專題:《Zend FrameWork框架入門教程》、《php優秀開發框架總結》、《Yii框架入門及常用技巧總結》、《ThinkPHP入門教程》、《php面向對象程序設計入門教程》、《php+mysql數據庫操作入門教程》及《php常見數據庫操作技巧匯總》

希望本文所述對大家基於Zend Framework框架的PHP程序設計有所幫助。

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved