当前位置:首页 > CMS教程 > 其它CMS > 列表

Zend Framework创建自己的动作助手详解

发布:smiling 来源: PHP粉丝网  添加日期:2021-07-13 14:38:02 浏览: 评论:0 

这篇文章主要介绍了Zend Framework创建自己的动作助手实现方法,结合实例形式分析了基于助手的抽象基类Zend_Controller_Action_Helper_Abstract实现自定义动作助手的相关技巧,需要的朋友可以参考下。

本文实例讲述了Zend Framework创建自己的动作助手实现方法,分享给大家供大家参考,具体如下:

助手的抽象基类是Zend_Controller_Action_Helper_Abstract,如要定义自己的助手,需要继承此类。

类的源代码如下:

  1. <?php 
  2. /** 
  3.  * @see Zend_Controller_Action 
  4.  */ 
  5. require_once 'Zend/Controller/Action.php'
  6. abstract class Zend_Controller_Action_Helper_Abstract 
  7.   /** 
  8.    * $_actionController 
  9.    * 
  10.    * @var Zend_Controller_Action $_actionController 
  11.    */ 
  12.   protected $_actionController = null; 
  13.   /** 
  14.    * @var mixed $_frontController 
  15.    */ 
  16.   protected $_frontController = null; 
  17.   /** 
  18.    * setActionController() 
  19.    * 
  20.    * @param Zend_Controller_Action $actionController 
  21.    * @return Zend_Controller_ActionHelper_Abstract Provides a fluent interface 
  22.    */ 
  23.   public function setActionController(Zend_Controller_Action $actionController = null) 
  24.   { 
  25.     $this->_actionController = $actionController
  26.     return $this
  27.   } 
  28.   /** 
  29.    * Retrieve current action controller 
  30.    * 
  31.    * @return Zend_Controller_Action 
  32.    */ 
  33.   public function getActionController() 
  34.   { 
  35.     return $this->_actionController; 
  36.   } 
  37.   /** 
  38.    * Retrieve front controller instance 
  39.    * 
  40.    * @return Zend_Controller_Front 
  41.    */ 
  42.   public function getFrontController() 
  43.   { 
  44.     return Zend_Controller_Front::getInstance(); 
  45.   } 
  46.   /** 
  47.    * Hook into action controller initialization 
  48.    * 
  49.    * @return void 
  50.    */ 
  51.   public function init() 
  52.   { 
  53.   } 
  54.   /** 
  55.    * Hook into action controller preDispatch() workflow 
  56.    * 
  57.    * @return void 
  58.    */ 
  59.   public function preDispatch() 
  60.   { 
  61.   } 
  62.   /** 
  63.    * Hook into action controller postDispatch() workflow 
  64.    * 
  65.    * @return void 
  66.    */ 
  67.   public function postDispatch() 
  68.   { 
  69.   } 
  70.   /** 
  71.    * getRequest() - 
  72.    * 
  73.    * @return Zend_Controller_Request_Abstract $request 
  74.    */ 
  75.   public function getRequest() 
  76.   { 
  77.     $controller = $this->getActionController(); 
  78.     if (null === $controller) { 
  79.       $controller = $this->getFrontController(); 
  80.     } 
  81.     return $controller->getRequest(); 
  82.   } 
  83.   /** 
  84.    * getResponse() - 
  85.    * 
  86.    * @return Zend_Controller_Response_Abstract $response 
  87.    */ 
  88.   public function getResponse() 
  89.   { 
  90.     $controller = $this->getActionController(); 
  91.     if (null === $controller) { 
  92.       $controller = $this->getFrontController(); 
  93.     } 
  94.     return $controller->getResponse(); 
  95.   } 
  96.   /** 
  97.    * getName() 
  98.    * 
  99.    * @return string 
  100.    */ 
  101.   public function getName() 
  102.   { 
  103.     $fullClassName = get_class($this); 
  104.     if (strpos($fullClassName'_') !== false) { 
  105.       $helperName = strrchr($fullClassName'_'); 
  106.       return ltrim($helperName'_'); 
  107.     } elseif (strpos($fullClassName'\\') !== false) { 
  108.       $helperName = strrchr($fullClassName'\\'); 
  109.       return ltrim($helperName'\\'); 
  110.     } else { 
  111.       return $fullClassName
  112.     } 
  113.   } 

助手基类提供的常用方法如下:

setActionController() 用来设置当前的动作控制器。

init(),该方法在实例化时由助手经纪人触发,可用来触发助手的初始化过程;

动作链中多个控制器使用相同的助手时,如要恢复状态时将十分有用。

preDispatch()分发动作之前触发。

postDispatch()分发过程结束时触发——即使preDispatch()插件已经跳过了该动作。清理时大量使用。

getRequest() 获取当前的请求对象。

getResponse() 获取当前的响应对象。

getName() 获取助手名。获取了下划线后面的类名部分,没有下划线则获取类的全名。

例如,如果类名为Zend_Controller_Action_Helper_Redirector,他将返回 Redirector,如果类名为FooMessage,将会返回全名。

举例说明自定义动作助手类

作用:解析传入的网址,返回各个部分。使用parse_url解析指定的网址。

用zendstudio新建一个zend framework项目helper_demo1。

新增文件:/helper_demo1/library/Application/Controller/Action/Helpers/UrlParser.php

  1. <?php 
  2. require_once 'Zend/Controller/Action/Helper/Abstract.php'
  3. class Application_Controller_Action_Helpers_UrlParser extends Zend_Controller_Action_Helper_Abstract 
  4.   public function __construct() 
  5.   { 
  6.   } 
  7.   /** 
  8.    * Parse url 
  9.    * 
  10.    * @param String $url 
  11.    * @return Array part of url 
  12.    */ 
  13.   public function parse($url
  14.   { 
  15.     return parse_url($url); 
  16.   } 

修改文件:/helper_demo1/application/Bootstrap.php

  1. <?php 
  2. class Bootstrap extends Zend_Application_Bootstrap_Bootstrap 
  3.   protected function _initAutoload() 
  4.   { 
  5.     $autoloader = Zend_Loader_Autoloader::getInstance(); 
  6.     $autoloader->registerNamespace(array('Application_')); 
  7.   } 
  8.   protected function _initActionHelpers() { 
  9.     //用前缀形式 
  10.     //Zend_Controller_Action_HelperBroker::addPrefix('Application_Controller_Action_Helpers'); 
  11.     //指定目录和前缀 
  12.     //Zend_Controller_Action_HelperBroker::addPath('/www/helper_demo1/library/Application/Controller/Action/Helpers', 
  13.     //                  'Application_Controller_Action_Helpers'); 
  14.     //new一个助手类传入 
  15.     Zend_Controller_Action_HelperBroker::addHelper(new Application_Controller_Action_Helpers_UrlParser); 
  16.   } 

修改测试action:/helper_demo1/application/controllers/IndexController.php

  1. <?php 
  2. class IndexController extends Zend_Controller_Action 
  3.   public function init() 
  4.   { 
  5.     /* Initialize action controller here */ 
  6.   } 
  7.   public function indexAction() 
  8.   { 
  9.     $urlParser = $this->_helper->getHelper('UrlParser'); 
  10.   var_dump($urlParser->parse('https://www.jb51.net/article/80479.htm')); 
  11.   } 

以上介绍了自定义动作助手类,以及简单的使用方法。

需要注意的就是什么是助手类的前缀,助手类的名称以及助手的路径

Tags: Framework创建动作

分享到: