如何在自动加载器上加载Zend 2类


How to load Zend 2 classes on autoloader

以前,我使用的是zend 1.x。我可以使用下面的代码自动加载zend类。

// autoload class from Zend Lib
require_once ABSPATH.'/classes/Zend/Loader/Autoloader.php'; 
$loader = Zend_Loader_Autoloader::getInstance();    
 try{
// database connection      
$dbo = Zend_Db::factory('pdo_mysql', array( 
        'host'     => DB_HOST, 
        'username' => DB_USER, 
        'password' => DB_PW, 
        'dbname'   => DB_PREFIX.DB_NAME
    )); 
$dbo->getConnection();
// save database adapter for easy usage in other classes
Zend_Db_Table::setDefaultAdapter($dbo);
Zend_Registry::set('db', $dbo);
}catch(Zend_Db_Adapter_Exception $e){
print $e;
 //header("Location: http://www.google.com/error/");
}

我正在升级到zend2,因为课程可能会更好。我可以知道如何自动加载吗?

如果您只是将ZF2用作一个独立的库,而没有使用完整的MVC框架,那么自动加载相当简单:

  1. 确保Zend目录在您的php include_path
  2. 使用spl_autoload_register推送自动加载器

以下基本上是Zend'Loader'StandardAutoloader::loadClass()在充当后备autloader时所做的操作:

spl_autoload_register(function($class) {
    $f = stream_resolve_include_path(str_replace('''', '/', $class) . '.php');
    if ($f !== false) {
        return include $f;
    }
    return false;
});

这将对所有类使用PSR-1自动加载机制,而不仅仅是Zend类。

或者,您可以只做以下操作:

require_once 'Zend/Loader/StandardAutoloader.php';
$autoloader = new Zend'Loader'StandardAutoloader(array(
    'fallback_autoloader' => true,
));
$autoloader->register();

如上所述,这将对所有类应用PSR-1自动加载。如果只想将此机制用于Zend类,则传递'fallback_autoloader' => false

您也可以通过Composer加载单个组件,然后只需要在执行脚本的开头包含require 'vendor/autoload.php';

我建议您研究ZF2提供的骨架应用程序,我不太了解ZF1,但据我所知ZF2有自己的自动加载机制,就自动加载而言,当您关注Skeleton Application时,您会注意到有一个Config''Application.Config.php,这是我们加载所有模块等的文件。作为示例,我将在下面加载我的文件。就设置连接等而言,您会在相同的目录树下找到它们,即"Config''local或Config''Global"。

 <?php
return array(
// This should be an array of module namespaces used in the application.
'modules' => array(
    'ZendDeveloperTools',
    'DoctrineModule',
    'DoctrineORMModule',
    'Application',
    'Administration',
    'Account',
    'Manufacturing',
    'GridMain',
),
// These are various options for the listeners attached to the ModuleManager
'module_listener_options' => array(
    'module_paths' => array(
        './module',
        './vendor',
    ),
    'config_glob_paths' => array(
        'config/autoload/{,*.}{global,local}.php',
    ),
),

);