Zend的MVC機制使用分析(二)
接著上面的一篇
把代碼貼上來
$front = Zend_Controller_Front::getInstance();
Zend_Layout::startMvc(array('layoutPath' => USVN_LAYOUTS_DIR));
$front->setRequest(new Zend_Controller_Request_Http());
$front->throwExceptions(true);
$front->setBaseUrl($config->url->base);
$router = new Zend_Controller_Router_Rewrite();
$routes_config = new USVN_Config_Ini(USVN_ROUTES_CONFIG_FILE, USVN_CONFIG_SECTION);
$router->addConfig($routes_config, 'routes');
$front->setRouter($router);
$front->setControllerDirectory(USVN_CONTROLLERS_DIR);
$front->dispatch();
上一篇把前兩句getInstance和startMvc兩個函數(shù)已經(jīng)讀完了,下面是繼續(xù)分析后面的代碼
setRequest($request) 這里是判斷request是否是繼承自Zend_Controller_Request_Abstract,如果是的話就把front的_request賦值為它。
這里需要了解下什么是Zend_Controller_Request_Abstract,它是所有request抽象出來的抽象類。Zend已經(jīng)提供了兩個實現(xiàn)類,Zend_Controller_Request_Http和Zend_Controller_Request_Simple,一般我們搭建服務(wù)器都是http請求,所以你的項目如果需要重新繼承的話,一般都直接繼承Zend_Controller_Request_Http。
Zend_controller_Request_Http中我們經(jīng)常會使用到的getQuery,getCookie,getRequestUri,getBasePath,getParams,getHeader等這些Http通常的選項都已經(jīng)有了。
繼續(xù)講它的基類Zend_Controller_Request_Abstract,這個類的方法包含:
回到代碼
$front->setRequest(new Zend_Controller_Request_Http());這里調(diào)用了Zend_Controller_Request_Http的構(gòu)造函數(shù),構(gòu)造函數(shù)在第一次調(diào)用的時候是$this->setRequestUri();其中的setRequestUri很多都是直接使用$_SERVER這個php全局變量中的數(shù)據(jù)來獲取requestUri的。
setRequestUri可以學(xué)到的是在不同的服務(wù)器中如何獲取requestUri(特別是在IIS中的$SERVER中不同的變量組合有不同的含義),比如http://172.23.11.160/usvn/item/usvn_test 這個url,它的requestUri就是/usvn/item/usvn_test
$front->throwExceptions(true); 將內(nèi)部的_throwExceptions標(biāo)志位設(shè)置為true;
$front->setbaseUrl("/usvn")這個做了兩件事情,首先是設(shè)置front內(nèi)部的_baseUrl屬性,其次調(diào)用Request的setBaseUrl,也是設(shè)置Zend_Controller_Request_Http的內(nèi)部_baseUrl屬性。
$router = new Zend_Controller_Router_Rewrite();
$routes_config = new USVN_Config_Ini(USVN_ROUTES_CONFIG_FILE, USVN_CONFIG_SECTION);
$router->addConfig($routes_config, 'routes');
$front->setRouter($router);
下面這三行就直接說,實際上就是使用Zend的Router模塊使用配置文件,router使用setRouter放入front里面。
最后一句
$front->dispatch();
這個函數(shù)也是最核心的一個函數(shù)。
這個函數(shù)首先注冊了一個插件Zend_Controller_Plugin_ErrorHandler,index為100,把插件的順序放在最后。
第二步存放了一個Helper,Zend_Controller_Action_Helper_ViewRenderer,index為-80
下面實例化了request,request是一個Zend_Controller_Request_Http類型。并將request的baseUrl設(shè)置為前面設(shè)置過的_baseUrl,就是"/usvn/item/usvn_test"
接著實例化了response,response是一個Zend_Controller_Response_Http();
下面使用plugins來對Request和Response進行設(shè)置,首先實際調(diào)用了Zend_Controller_Plugin_Broker的setRequest函數(shù),這個函數(shù)循環(huán)遍歷broker管理的所有插件,調(diào)用插件的setRequest($request)函數(shù)(如果有的話)。
接下來初始化router,和設(shè)置router的參數(shù)。router已經(jīng)在前面設(shè)置過了,就是Zend_Controller_Router_Rewrite類型
初始化分發(fā)器dispatcher,分發(fā)器我們是第一次看到,Zend_Controller_Dispatcher_Standard類。分發(fā)器以后再說。
下面的流程:
調(diào)用插件的routeStartup對request進行處理
調(diào)用router的route處理request
調(diào)用插件的routeShutdown對request進行處理
調(diào)用插件的dispatchLoopStartup對request進行處理
進入循環(huán)分發(fā)過程
調(diào)用插件的preDispatch對request進行處理
調(diào)用dispatcher的dispatch處理request和response
調(diào)用插件的postDispatch對request進行處理
跳出循環(huán)分發(fā)過程
調(diào)用插件的dispatchLoopShutdown對request進行處理
發(fā)送response
相關(guān)文章
使用PHP+MySql+Ajax+jQuery實現(xiàn)省市區(qū)三級聯(lián)動功能示例
下面小編就為大家?guī)硪黄褂肞HP+MySql+Ajax+jQuery實現(xiàn)省市區(qū)三級聯(lián)動功能示例。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-09-09Codeigniter整合Tank Auth權(quán)限類庫詳解
相交其他CodeIgniter的類庫,tank_auth,配置簡單,使用也簡單,并且作者也一直在更新。這篇文章主要介紹了Codeigniter整合Tank Auth權(quán)限類庫詳解,需要的朋友可以參考下2014-06-06yii框架表單模型使用及以數(shù)組形式提交表單數(shù)據(jù)示例
這篇文章主要介紹了yii框架表單模型使用及以數(shù)組形式提交表單數(shù)據(jù)示例,需要的朋友可以參考下2014-04-04PHP傳值到不同頁面的三種常見方式及php和html之間傳值問題
這篇文章主要介紹了PHP傳值到不同頁面的三種常見方式及php和html之間傳值問題的相關(guān)資料,需要的朋友可以參考下2015-11-11php 二維數(shù)組快速排序算法的實現(xiàn)代碼
這篇文章主要介紹了php 二維數(shù)組快速排序算法的實現(xiàn)代碼的相關(guān)資料,希望通過本文能幫助到大家,讓大家實現(xiàn)這樣的功能,需要的朋友可以參考下2017-10-10PHP配置把錯誤日志以郵件方式發(fā)送方法(Windows系統(tǒng))
這篇文章主要介紹了PHP配置把錯誤日志以郵件方式發(fā)送方法(Windows系統(tǒng)),本文給出了配置示例和使用例子,需要的朋友可以參考下2015-06-06