国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁(yè) > 語(yǔ)言 > PHP > 正文

YII Framework的filter過(guò)濾器用法分析

2024-05-04 23:44:43
字體:
來(lái)源:轉(zhuǎn)載
供稿:網(wǎng)友
這篇文章主要介紹了YII Framework的filter過(guò)濾器用法,結(jié)合實(shí)例形式分析了filter過(guò)濾器的功能,使用技巧與相關(guān)注意事項(xiàng),需要的朋友可以參考下
 

本文實(shí)例講述了YII Framework的filter過(guò)濾器用法。分享給大家供大家參考,具體如下:

首先看官方給出的說(shuō)明文檔,什么是過(guò)濾器,過(guò)濾器的作用,過(guò)濾器的規(guī)則,過(guò)濾器的定義方法等等。

然后對(duì)過(guò)濾器進(jìn)行一個(gè)總結(jié)。

http://www.yiiframework.com/doc/guide/1.1/zh_cn/basics.controller

過(guò)濾器是一段代碼,可被配置在控制器動(dòng)作執(zhí)行之前或之后執(zhí)行。例如, 訪問(wèn)控制過(guò)濾器將被執(zhí)行以確保在執(zhí)行請(qǐng)求的動(dòng)作之前用戶已通過(guò)身份驗(yàn)證;性能過(guò)濾器可用于測(cè)量控制器執(zhí)行所用的時(shí)間。

一個(gè)動(dòng)作可以有多個(gè)過(guò)濾器。過(guò)濾器執(zhí)行順序?yàn)樗鼈兂霈F(xiàn)在過(guò)濾器列表中的順序。過(guò)濾器可以阻止動(dòng)作及后面其他過(guò)濾器的執(zhí)行

過(guò)濾器可以定義為一個(gè)控制器類的方法。方法名必須以 filter 開(kāi)頭。例如,現(xiàn)有的 filterAccessControl 方法定義了一個(gè)名為 accessControl 的過(guò)濾器。 過(guò)濾器方法必須為如下結(jié)構(gòu):

public function filterAccessControl($filterChain){  // 調(diào)用 $filterChain->run() 以繼續(xù)后續(xù)過(guò)濾器與動(dòng)作的執(zhí)行。}

其中的 $filterChain (過(guò)濾器鏈)是一個(gè) CFilterChain 的實(shí)例,代表與所請(qǐng)求動(dòng)作相關(guān)的過(guò)濾器列表。在過(guò)濾器方法中, 我們可以調(diào)用 $filterChain->run() 以繼續(xù)執(zhí)行后續(xù)過(guò)濾器和動(dòng)作。

過(guò)濾器也可以是一個(gè) CFilter 或其子類的實(shí)例。如下代碼定義了一個(gè)新的過(guò)濾器類:

class PerformanceFilter extends CFilter{  protected function preFilter($filterChain)  {    // 動(dòng)作被執(zhí)行之前應(yīng)用的邏輯    return true; // 如果動(dòng)作不應(yīng)被執(zhí)行,此處返回 false  }  protected function postFilter($filterChain)  {    // 動(dòng)作執(zhí)行之后應(yīng)用的邏輯  }}

要對(duì)動(dòng)作應(yīng)用過(guò)濾器,我們需要覆蓋 CController::filters() 方法。此方法應(yīng)返回一個(gè)過(guò)濾器配置數(shù)組。例如:

class PostController extends CController{  ......  public function filters()  {    return array(      'postOnly + edit, create',      array(        'application.filters.PerformanceFilter - edit, create',        'unit'=>'second',      ),    );  }}

上述代碼指定了兩個(gè)過(guò)濾器: postOnly 和 PerformanceFilter。 postOnly 過(guò)濾器是基于方法的(相應(yīng)的過(guò)濾器方法已在 CController 中定義); 而 performanceFilter 過(guò)濾器是基于對(duì)象的。路徑別名application.filters.PerformanceFilter 指定過(guò)濾器類文件是protected/filters/PerformanceFilter。我們使用一個(gè)數(shù)組配置 PerformanceFilter ,這樣它就可被用于初始化過(guò)濾器對(duì)象的屬性值。此處 PerformanceFilter 的 unit 屬性值將被初始為 second。

使用加減號(hào),我們可指定哪些動(dòng)作應(yīng)該或不應(yīng)該應(yīng)用過(guò)濾器。上述代碼中, postOnly 應(yīng)只被應(yīng)用于 edit 和create 動(dòng)作,而 PerformanceFilter 應(yīng)被應(yīng)用于 除了 edit 和 create 之外的動(dòng)作。 如果過(guò)濾器配置中沒(méi)有使用加減號(hào),則此過(guò)濾器將被應(yīng)用于所有動(dòng)作。

過(guò)濾器功能:

用于對(duì)訪問(wèn)者和數(shù)據(jù)的過(guò)濾和對(duì)訪問(wèn)操作的記錄

使用方法:

一作為controller的一個(gè)方法。方法名以filter開(kāi)頭。

public function filterAccessControl($filterChain){ echo "--->filterAccessControl";  $filterChain->run();}

二定義對(duì)立的filter類,要求extends CFilter。

CFilter

<?php /**  * CFilter is the base class for all filters.  *  * A filter can be applied before and after an action is executed.  * It can modify the context that the action is to run or decorate the result that the  * action generates.  *  * Override {@link preFilter()} to specify the filtering logic that should be applied  * before the action, and {@link postFilter()} for filtering logic after the action.  *  * @author Qiang Xue <qiang.xue@gmail.com>  * @version $Id: CFilter.php 2799 2011-01-01 19:31:13Z qiang.xue $  * @package system.web.filters  * @since 1.0  */ class CFilter extends CComponent implements IFilter {   /**    * Performs the filtering.    * The default implementation is to invoke {@link preFilter}    * and {@link postFilter} which are meant to be overridden    * child classes. If a child class needs to override this method,    * make sure it calls <code>$filterChain->run()</code>    * if the action should be executed.    * @param CFilterChain $filterChain the filter chain that the filter is on.    */   public function filter($filterChain)   {     if($this->preFilter($filterChain))     {       $filterChain->run();       $this->postFilter($filterChain);     }   }   /**    * Initializes the filter.    * This method is invoked after the filter properties are initialized    * and before {@link preFilter} is called.    * You may override this method to include some initialization logic.    * @since 1.1.4    */   public function init()   {   }   /**    * Performs the pre-action filtering.    * @param CFilterChain $filterChain the filter chain that the filter is on.    * @return boolean whether the filtering process should continue and the action    * should be executed.    */   protected function preFilter($filterChain)   {     return true;   }   /**    * Performs the post-action filtering.    * @param CFilterChain $filterChain the filter chain that the filter is on.    */   protected function postFilter($filterChain)   {   } }

下面舉例說(shuō)明兩種filter規(guī)則的使用:

SiteController.php

<?php class SiteController extends Controller {   public function init()   {     //$this->layout='mylayout';   }   public function filters()     {       return array(         'AccessControl - create',         array(           'application.filters.MyFilter + create',         ),       );   }   public function filterAccessControl($filterChain)   {           echo "--->filterAccessControl";       $filterChain->run();   }   public function actionCreate() {     echo "--->create action";   }   public function actionPrint() {     echo "--->print action";   } 

/www/yii_dev/testwebap/protected# tree 
.
├── commands
│   ├── shell
│   ├── TestCommand.php
│   └── TestCommand.php~
├── components
│   ├── Controller.php
│   └── UserIdentity.php
├── config
│   ├── console.php
│   ├── main.php
│   └── test.php
├── controllers
│   ├── post
│   │   └── UpdateAction.php
│   ├── SiteController.php
│   ├── TestTestController.php
│   └── UserController.php
├── filters
│   └── MyFilter.php
 MyFilter.php

<?php class MyFilter extends CFilter {   protected function preFilter ($filterChain)   {     // logic being applied before the action is executed         echo "-->MyFilter-->pre";     return true; // false if the action should not be executed   }   protected function postFilter ($filterChain)   {     echo "-->MyFilter-->post";   } } 

http://www.localyii.com/testwebap/index.php?r=site/print

--->filterAccessControl--->print action

http://www.localyii.com/testwebap/index.php?r=site/create

-->MyFilter-->pre--->create action-->MyFilter-->post

public function filters(){  return array(    'AccessControl - create',    array(      'application.filters.MyFilter + create,print',    ),  );}

http://www.localyii.com/testwebap/index.php?r=site/print
--->filterAccessControl-->MyFilter-->pre--->print action-->MyFilter-->post

以上可以看到filter的具體執(zhí)行流程。

在filters中有-、+
具體功能是
+表示僅僅作用于這一些action
-后邊跟action名稱列表。表示排除在外。
如果沒(méi)有-、+則會(huì)應(yīng)用的所有的action



注:相關(guān)教程知識(shí)閱讀請(qǐng)移步到PHP教程頻道。
發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表

圖片精選

主站蜘蛛池模板: 布尔津县| 通州市| 绥阳县| 长沙县| 东海县| 商都县| 栾城县| 徐闻县| 利津县| 友谊县| 马关县| 汝南县| 集安市| 洛隆县| 孝义市| 大邑县| 余江县| 冕宁县| 准格尔旗| 武陟县| 黄平县| 曲阳县| 灌南县| 长春市| 宁国市| 民县| 泸州市| 朔州市| 玉门市| 南溪县| 德格县| 鹤壁市| 城市| 双流县| 深泽县| 开江县| 开远市| 崇仁县| 饶阳县| 彰化市| 沿河|