本文實例講述了Zend Framework中Bootstrap類用法。分享給大家供大家參考,具體如下:
Zend_Application_Bootstrap_Bootstrapper
Zend_Application_Bootstrap_Bootstrapper是所有引導(dǎo)類必須實現(xiàn)的基本接口。基本功能是用于配置,注冊資源,引導(dǎo)(無論是單個資源或整個應(yīng)用程序),并運行應(yīng)用程序。
接口方法:
Zend_Application_Bootstrap_Bootstrapper Interface
Method | Return Value | Parameters | Description |
---|---|---|---|
__construct( $application ) | Void |
| 構(gòu)造方法。接受一個參數(shù),參數(shù)要求是一個Zend_Application對象,或另一個引導(dǎo)對象。 |
setOptions( array $options) | Zend_Application_Bootstrap_Bootstrapper |
| 通常情況下, 選項都可以匹配映射到對應(yīng)的setter;否則,選項僅僅會被存儲,便于以后查找 |
getApplication() | Zend_Application |Zend_Application_Bootstrap_Bootstrapper | N/A | 獲取application實例 |
getEnvironment() | String | N/A | 獲取environment |
getClassResources() | Array | N/A | 獲取可以可用的資源 |
bootstrap($resource = null) | Mixed |
| 如果 $resource為空,注冊所有資源.如果為字符串注冊指定的資源;如果是數(shù)組, 只注冊指定的資源. |
run() | Void | N/A | 執(zhí)行引導(dǎo). |
Zend_Application_Bootstrap_ResourceBootstrapper
Zend_Application_Bootstrap_ResourceBootstrapper是一個接口,用于引導(dǎo)類加載注冊外部資源 。 也就是說,一個或多個資源不會直接在類中定義,而是通過插件形式引入。它應(yīng)該與Zend_Application_Bootstrap_Bootstrapper結(jié)合使用; Zend_Application_Bootstrap_BootstrapAbstract實現(xiàn)了這個功能。
接口方法:
Zend_Application_Bootstrap_ResourceBootstrapper Interface
Method | Return Value | Parameters | Description |
---|---|---|---|
registerPluginResource($resource, $options = null) | Zend_Application_Bootstrap_ResourceBootstrapper |
| 用于注冊資源類,通過可選選項傳遞資源 |
unregisterPluginResource($resource) | Zend_Application_Bootstrap_ResourceBootstrapper |
| 刪除插件資源 |
hasPluginResource($resource) | Boolean |
|
|
getPluginResource($resource) | Zend_Application_Resource_Resource |
|
|
getPluginResourceNames() | Array | N/A |
|
setPluginLoader(Zend_Loader_PluginLoader_Interface $loader) | Zend_Application_Bootstrap_ResourceBootstrapper |
|
|
getPluginLoader() | Zend_Loader_PluginLoader_Interface | N/A |
|
Zend_Application_Bootstrap_BootstrapAbstract
Zend_Application_Bootstrap_BootstrapAbstract是一個抽象類,它提供了一個通用的引導(dǎo)基本功能。它實現(xiàn)了Zend_Application_Bootstrap_Bootstrapper和Zend_Application_Bootstrap_ResourceBootstrapper。
Zend_Application_Bootstrap_BootstrapAbstract Methods
Method | Return Value | Parameters | Description |
---|---|---|---|
__construct($application) | Void |
| Accepts either a Zend_Application or a Zend_Application_Bootstrap_Bootstrapper object as the sole argument. |
setOptions(array $options) | Zend_Application_Bootstrap_Bootstrapper |
| 所有選項都可以映射到選項指定的setter??, 否則,該選項將只是被存儲供以后查找 例如,如果在擴展類中定義一個setFoo() 方法,可以通過foo選項傳遞值 |
getOptions() | Array | N/A |
|
hasOption($key) | Boolean |
|
|
getOption($key) | Mixed |
| 不存在返回 NULL |
setApplication(Zend_Application | Zend_Application_Bootstrap_Bootstrapper $application) | Zend_Application_Bootstrap_BootstrapAbstract |
|
|
getApplication() | Zend_Application |Zend_Application_Bootstrap_Bootstrapper | N/A |
|
getEnvironment() | String | N/A |
|
getClassResources() | Array | N/A |
|
getContainer() | Object | N/A | 獲取存儲資源的容器。如果沒有容器,可以通過Zend_Registry注冊,然后返回一個Zend_Registry實例。 |
setContainer($container) | Zend_Application_Bootstrap_BootstrapAbstract |
|
|
hasResource($name) | Boolean |
|
|
getResource($name) | Mixed |
|
|
bootstrap($resource = null) | Mixed |
| 如果 $resource為空,注冊所有資源.如果為字符串注冊指定的資源;如果是數(shù)組, 只注冊指定的資源. |
run() | Void | N/A |
|
__call($method, $args) | Mixed |
| 為了方便可以用'bootstrap<ResourceName>()'代替 bootstrap() 引導(dǎo)注冊資源。 |
Zend_Application_Bootstrap_Bootstrap
Zend_Application_Bootstrap_Bootstrap是Zend_Application_Bootstrap_BootstrapAbstract具體實現(xiàn)。它的主要功能是,注冊資源,然后運行 run() 方法。
在大多數(shù)情況下,你可以根據(jù)自己的引導(dǎo)需求繼承這個類或直接使用這個類,并來注冊資源插件。
啟用 Application 自動加載功能
此外,該引導(dǎo)的實現(xiàn)提供了自動加載指定“命名空間”或指定資源類的前綴的功能
本質(zhì)上,它實例化一個Zend_Application_Module_Autoloader的對象,參數(shù)為命名空間和引導(dǎo)類的目錄。可以開啟這個功能,通過 “appnamespace”配置選項設(shè)置命名空間。
As an INI example:
appnamespace = "Application"
Or in XML:
<appnamespace>Application</appnamespace>
默認(rèn)情況下,Zend_Tool提供“Application”命名空間。
或者,可以在bootstrap類中通過$_appNamespace屬性指定命名空間。
class Bootstrap extends Zend_Application_Bootstrap_Bootstrap{ protected $_appNamespace = 'Application';}