zend_Application 流程

Zend_Application 负责加载配置以及初始化资源,所以index.php 会有这行代码

/** Zend_Application */
require_once 'Zend/Application.php';

// Create application, bootstrap, and run
$application = new Zend_Application(
    APPLICATION_ENV,
    APPLICATION_PATH . '/configs/application.ini'
);

$application->bootstrap()
            ->run();
复制代码

Zend_application 如何初始化流程,下面是一个类图

  上面大致画了一下Zend_Application 的类图的关系,Zend_Application 与 bootStrap 是聚合的关系,爱的死去活来,爱的只要你无怨,他也无悔。zend_Application 的主要工作就是加载配置文件application.ini 以及命名空间。其他的工作会代理给bootstrap类处理。

  bootstrap主要负责加载两类资源,分别对应最上面的两个接口。

  1.Zend_Application_Bootstrap_Bootstrapper 是 bootstrap 类的接口,Zend_Application_Bootstrap_BootstrapAbstract 实现Zend_Application_Bootstrap_Bootstrapper 的getClassResources 方法的代码

复制代码
 if (null === $this->_classResources) {
            if (version_compare(PHP_VERSION, '5.2.6') === -1) {
                $class        = new ReflectionObject($this);
                $classMethods = $class->getMethods();
                $methodNames  = array();

                foreach ($classMethods as $method) {
                    $methodNames[] = $method->getName();
                }
            } else {
                $methodNames = get_class_methods($this);
            }

            $this->_classResources = array();
            foreach ($methodNames as $method) {
                if (5 < strlen($method) && '_init' === substr($method, 0, 5)) {
                    $this->_classResources[strtolower(substr($method, 5))] = $method;
                }
            }
        }
复制代码

所谓的classResource 就是在bootstrap 以_init 开头定义的方法 比如

复制代码
1.class Bootstrap extends Zend_Application_Bootstrap_Bootstrap
2.{
3.    protected function _initView()
4.    {
5.        // Initialize view
6.        $view = new Zend_View();
7.        $view->doctype('XHTML1_STRICT');
8.        $view->headTitle('My First Zend Framework Application');
9. 
10.        // Add it to the ViewRenderer
11.        $viewRenderer = Zend_Controller_Action_HelperBroker::getStaticHelper(
12.            'ViewRenderer'
13.        );
14.        $viewRenderer->setView($view);
15. 
16.        // Return it, so that it can be stored by the bootstrap
17.        return $view;
18.    }
19.}
复制代码

2.Zend_Application_Bootstrap_ResourceBootstrapper 定义是加载资源的接口,就是我们在application.ini 以resource开头定义的资源比如

resources.db.adapter           ="MYSQLI"
resources.db.params.host        ="localhost"
resources.db.params.username    ="root"
resources.db.params.password    ="123456"
resources.db.params.dbname    ="test"

  资源的加载流程,通过zend_Application 加载配置,通过Zend_Loader_PluginLoader 进行加载文件,并在Zend_Application_Bootstrap_BootstrapAbstract的 loadPluginResource方法进行初始化资源类。

  加载两类资源的入口在Zend_Application_Bootstrap_BootstrapAbstract的 _bootstrap 方法

复制代码
protected function _bootstrap($resource = null)
    {
        if (null === $resource) {
            foreach ($this->getClassResourceNames() as $resource) {
                $this->_executeResource($resource);
            }

            foreach ($this->getPluginResourceNames() as $resource) {
                $this->_executeResource($resource);
            }
        } elseif (is_string($resource)) {
            $this->_executeResource($resource);
        } elseif (is_array($resource)) {
            foreach ($resource as $r) {
                $this->_executeResource($r);
            }
        } else {
            throw new Zend_Application_Bootstrap_Exception('Invalid argument passed to ' . __METHOD__);
        }
    }
复制代码

  分别加载calssResource 和 配置的 resource

    注意 :  以上是zend  framwork 1   而非 2。


Zend Framework教程-Autoloading使用方法

发布时间:2014-01-28 | 阅读次数: 347次 | 分类: ZendFramework

通常,只需将需要引入包含类,然后实例化它即可。由于Zend_Loader_Autoloader采用的单例模式,可以使用getInstance()方法来获取一个实例。

require_once 'Zend/Loader/Autoloader.php';Zend_Loader_Autoloader::getInstance();

默认情况下,可以加载命名空间前缀为"Zend_"或 "ZendX_"的任何类,只要确保已经指定include_path。

如果想使用其他的命名空间前缀?最好的,最简单的方法是调用registerNamespace() 方法。您可以通过传递一个单一的命名空间前缀,或一个数组:

require_once 'Zend/Loader/Autoloader.php';$loader = Zend_Loader_Autoloader::getInstance();$loader->registerNamespace('Foo_');$loader->registerNamespace(array('Foo_', 'Bar_'));

或者,你可以把Zend_Loader_Autoloader作为一个“备用”自动加载器。这意味着如果命名空间无论是否定义,都会尝试自动加载。
$loader->setFallbackAutoloader(true);
(注意:这种方式是不推荐的,尽量不要使用)。


 Zend_Loader_Autoloader的内部实现是使用 Zend_Loader::loadClass() 加载类的。该方法的使用 include() 来尝试加载给定的类文件。 include()将返回一个布尔值,如果没有成功返回FALSE - ??而且还发出PHP警告。 可能会导致以下问题:

如果启用了display_errors,警告将包含在输出中。

根据你所配置的error_reporting级别,它也可以输出到日志中。

可以禁止这些错误消息,具体如下:(但注意,display_errors启用时,错误日志将始终显示。)

$autoloader->suppressNotFoundWarnings(true);




选择一个Zend Framework的版本

ZendFramework/|-- 1.9.2/|   |-- library/|-- ZendFramework-1.9.1-minimal/|   |-- library/|-- 1.8.4PL1/|   |-- library/|-- 1.8.4/|   |-- library/|-- ZendFramework-1.8.3/|   |-- library/|-- 1.7.8/|   |-- library/|-- 1.7.7/|   |-- library/|-- 1.7.6/|   |-- library/

$autoloader->setZfPath($path, 'latest');

$autoloader->setZfPath($path, '1.8');

$autoloader->setZfPath($path, '1.7.7');

也可以使用配置文件

[production]autoloaderZfPath = "path/to/ZendFramework"autoloaderZfVersion = "1.7.7" [qa]autoloaderZfVersion = "1.8" [development]autoloaderZfVersion = "latest"

Autoloader接口


注:命名空间前缀和PHP命名空间
PHP5.3已经发布。该版本中,PHP现在已经正式支持命名空间。
然而,Zend Framework的命名空间和PHP 5.3的命名空间完全不同的。 Zend Framework中,提到的“命名空间”,是指一个类前缀。例如,所有的Zend Framework的类名称的前缀“Zend_”。 这是我们指定的“命名空间”。
在Zend Framework 2.0.0使用了原生的PHP命名空间。

 

自动加载器除了能够指定任意回调以外,Zend Framework还定义了一个需要自动加载类实现的接口Zend_Loader_Autoloader_Interface:



interface Zend_Loader_Autoloader_Interface{    public function autoload($class);}


如果您希望在Zend Framework中使用自定义的自动加载器,可以使用 Zend_Loader_Autoloader的 pushAutoloader()和unshiftAutoloader()方法。

通过这些方法将在Zend Framework的内部自动装载器之后追加或之前使用自定义的加载器。

   每个方法接受一个可选的第二个参数,类的命名空间前缀。自动加载器只查找给定的类前缀。如果不是指定的类前缀,将跳过自动加载器 , 这可能是一种性能改进方式。


当使用这个接口时,你需要传递类实例到Zend_Loader_Autoloader类的pushAutoloader()和unshiftAutoloader()方法,具体如下:


// Append function 'my_autoloader' to the stack,// to manage classes with the prefix 'My_':$loader->pushAutoloader('my_autoloader', 'My_'); // Prepend static method Foo_Loader::autoload() to the stack,// to manage classes with the prefix 'Foo_':$loader->unshiftAutoloader(array('Foo_Loader', 'autoload'), 'Foo_');


// Assume Foo_Autoloader implements Zend_Loader_Autoloader_Interface:$foo = new Foo_Autoloader(); $autoloader->pushAutoloader($foo, 'Foo_');


Zend_Loader_Autoloader的相关方法



Zend_Loader_Autoloader Methods
MethodReturn ValueParametersDescription
getInstance()Zend_Loader_AutoloaderN/A

获取实例

resetInstance()voidN/A

重置Zend_Loader_Autoloadersingleton实例的状态,恢复它的原始状态,注销所有的自动加载器回调和所有注册的命名空间。

autoload($class)string|FALSE
  • $class,required. A string class name to load.

试图加载一个类。

setDefaultAutoloader($callback)Zend_Loader_Autoloader
  • $callback,required.

指定默认的加载器回调

getDefaultAutoloader()callbackN/A

获取默认的加载器接口;默认是Zend_Loader::loadClass().

setAutoloaders(array $autoloaders)Zend_Loader_Autoloader
  • $autoloaders,required.

设置在自动加载器栈使用具体的自动加载器列表。自动加载器列表中的每个项目必须是PHPcallback。

getAutoloaders()ArrayN/A

 

getNamespaceAutoloaders($namespace)Array
  • $namespace,required

获取所有已注册的自动加载器来加载一个特定的的命名空间。

registerNamespace($namespace)Zend_Loader_Autoloader
  • $namespace,required.

注册命名空间. If$namespace is a string, it registers that namespace; if it's an array of strings, registers each as a namespace.

unregisterNamespace($namespace)Zend_Loader_Autoloader
  • $namespace,required.


getRegisteredNamespaces()ArrayN/A


suppressNotFoundWarnings($flag = null)boolean|Zend_Loader_Autoloader
  • $flag,optional.

错误提示

setFallbackAutoloader($flag)Zend_Loader_Autoloader
  • $flag,required.

 

isFallbackAutoloader()BooleanN/A

 

getClassAutoloaders($class)Array
  • $class,required.

 

unshiftAutoloader($callback, $namespace = '')Zend_Loader_Autoloader
  • $callback,required. A valid PHPcallback

  • $namespace,optional. A string representing a class prefix namespace.

 

pushAutoloader($callback, $namespace = '')Zend_Loader_Autoloader
  • $callback,required. A valid PHPcallback

  • $namespace,optional. A string representing a class prefix namespace.

 

removeAutoloader($callback, $namespace = '')Zend_Loader_Autoloader
  • $callback,required. A valid PHPcallback

  • $namespace,optional. A string representing a class prefix namespace, or an array of namespace strings.





  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值