zend framework多模块多布局配置

2015-01-24信息快讯网

zend framework对多模块的支持是很好的,但是可能是由于功能太过强大的缘故,部署起来并不是很容易。

许多人在使用过程中都会遇到这样那样的问题,而且zend framework现在已经到1.11版本了,网络上的很多资料都还停留在旧版本上,因此我在这里以当前的最新版本1.11为例,来简单介绍一下如何使用zend framework创建模块化的应用程序。由于今后框架的版本升级,有些内容可能会过时,请及时参阅最新的使用手册。

1、准备工作

首先假设你已经部署了web服务器和php,并下载了zend framework的最新版本,创建了一个最原始的zend framework项目,并可以访问默认的action了。你可以使用zend framework工具来创建项目,具体操作参见使用zend framework创建项目。当然也可以自己手动建立文件夹和文件,参见zend framework推荐的项目目录结构。

简单地看一下默认的几个重要目录。
首先是public,它不但存放了程序的入口点index.php,还可以存放图片,css,javascript文件等。
其次是library,用于存放一些类库,包括你自己定义的或第三方的类库。
然后是test,用于存放单元测试等测试文件的。
最后,也是和我们这里要讲的关系最大的目录――application。进到application目录下,会有以下目录:
configs:存放配置文件,一般会有一个主配置文件application.ini;
controllers:操制器,如默认的IndexController.php;
models:存放业务逻辑,数据模型等文件;
views:视图层的脚本,一般以.phtml为后缀名;
modules:模块目录,使用工具默认选项自动生成的是没有这个目录的,需要手动添加。modules底下可以包含多个以模块名命名的文件夹,如admin,默认是default,一个文件夹代表一个模块,其下的目录结构与application目录类似,又可以包含controllers,models,views等目录。需要注意的是模块下的controllers下面的文件的类名请加上模块名前缀,如application/modules/admin/controllers/IndexController.php的类名为Admin_IndexController。

如果你需要在项目中方便的使用你自己写的一些类库(如名称空间是Rockux),或是第三方的类库,可以修改application.ini文件,添加以下行:

 
autoloaderNamespaces.rockux = "Rockux_" 
autoloaderNamespaces.thirdParty = "ThirdPartyLibrary_" 

当然你也可以根据需要多添加几个,不过请注意最后面的下划线。

2、建立模块
现在我们来创建一个admin模块,目录如下:
application/modules/admin/controllers
application/modules/admin/models
application/modules/admin/views
application/modules/admin/views/scripts
application/modules/admin/views/helpers
application/modules/admin/views/filters
并创建以下文件:
application/modules/admin/controllers/IndexController.php(类名为Admin_IndexController)
application/modules/admin/views/scripts/index/index.phtml

除了新建模块文件之外,还需要更改配置文件application.ini,删除以下行,如果有的话:
 
resources.frontController.controllerDirectory = APPLICATION_PATH"/controllers" 

再加上如下行:
 
resources.frontController.moduleDirectory = APPLICATION_PATH "/modules" 
resources.frontController.moduleControllerDirectoryName = "controllers" 
resources.frontController.defaultModule = "default" 
resources.modules[] 

这样,再访问http://localhost/admin,应该就能看到admin模块输出的内容了。
如果我们要充分发挥模块的强大功能,我们还需要为模块添加一个启动文件――Bootstrap.php。它可以使得你在事个模块中方便的使用类资源,models, filters, helpers等。在admin下新建Bootstrap.php,代码如下:
 
class Admin_Bootstrap extends Zend_Application_Module_Bootstrap 
{ 
} 

并且在application/Bootstrap.php文件里加入以下方法:
 
protected function _initAppAutoload() 
{ 
$autoloader = new Zend_Application_Module_Autoloader(array( 
'namespace' => 'App', 
'basePath' => dirname(__FILE__), 
)); 
return $autoloader; 
} 

 
resources.layout.layoutPath = APPLICATION_PATH "/layouts/scripts" 
resources.layout.layout = "layout" 
admin.resources.layout.layout = "admin" 

第二种,不同模块的布局脚本文件分别存放在各自的模块文件夹下
可以在application下新建如下目录和文件:
application/layouts/scripts/layout.phtml
application/modules/admin/layouts/scripts/layout.phtml

在配置文件application.ini中添加如下几行:
 
resources.layout.layoutPath = APPLICATION_PATH "/layouts/scripts" 
resources.layout.layout = "layout" 
admin.resources.layout.layoutPath = APPLICATION_PATH "/modules/admin/layouts/scripts" 

不论是第一种还是第二种,这时如果访问http://localhost/admin,你会发现系统并没有使用期望的admin.phtml作为布局文件,而是使用了默认的layout.phtml。这是因为admin那行配置并不是系统默认能处理的有效配置,所以我们要自己来处理它。

我们新建文件:library/Rockux/Controller/Action/Helper/LayoutLoader.php,

针对第一种情况代码如下:
 
class Rockux_Controller_Action_Helper_LayoutLoader extends Zend_Controller_Action_Helper_Abstract 
{ 

public function preDispatch() 
{ 
$bootstrap = $this->getActionController() 
->getInvokeArg('bootstrap'); 
$config = $bootstrap->getOptions(); 
$module = $this->getRequest()->getModuleName(); 
if (isset($config[$module]['resources']['layout']['layout'])) { 
$layoutScript = $config[$module]['resources']['layout']['layout']; 
$this->getActionController() 
->getHelper('layout') 
->setLayout($layoutScript); 
} 
} 

} 

针对第二种情况代码如下:
 
class Rockux_Controller_Action_Helper_LayoutLoader extends Zend_Controller_Action_Helper_Abstract 
{ 

public function preDispatch() 
{ 
$bootstrap = $this->getActionController() 
->getInvokeArg('bootstrap'); 
$config = $bootstrap->getOptions(); 
$module = $this->getRequest()->getModuleName(); 
if (isset($config[$module]['resources']['layout']['layoutPath'])) { 
$layoutPath = 
$config[$module]['resources']['layout']['layoutPath']; 
$this->getActionController() 
->getHelper('layout') 
->setLayoutPath($layoutPath); 
} 
} 
} 

接下来我们还需要将它添加到application/Bootstrap.php里去
 
protected function _initLayoutHelper() 
{ 
$this->bootstrap('frontController'); 
$layout = Zend_Controller_Action_HelperBroker::addHelper( 
new Rockux_Controller_Action_Helper_LayoutLoader()); 
} 

再次访问http://localhost/admin,应当就可以看到使用指定的布局文件了。
如果要针对某个特定的controller使用特定的layout,可以在controller的init()方法里添加如下代码:
 
$layout = Zend_Layout::getMvcInstance(); 
$layout->setLayout('layout_special'); 

PHP Warning: PHP Startup: Unable to load dynamic library \ D:/php5/ext/php_mysqli.dll\
PHP Parse Error: syntax error, unexpected $end 错误的解决办法
PHP fgetcsv 定义和用法(附windows与linux下兼容问题)
php提示undefined index的几种解决方法
php的array_multisort()使用方法介绍
php array的学习笔记
php array的学习笔记
iis下php mail函数的sendmail配置方法(官方推荐)
MySQL的FIND_IN_SET函数使用方法分享
smarty巧妙处理iframe中内容页的代码
PHP及Zend Engine的线程安全模型分析
php数组函数序列之end() - 移动数组内部指针到最后一个元素,并返回该元素的值
Array of country list in PHP with Zend Framework
mac下使用brew配置环境的步骤分享
Views rows style模板重写代码
8个出色的WordPress SEO插件收集
让你成为更出色的PHP开发者的10个技巧
PHP Session_Regenerate_ID函数双释放内存破坏漏洞
重新封装zend_soap实现http连接安全认证的php代码
array_multisort实现PHP多维数组排序示例讲解
php关于array_multisort多维数组排序的使用说明
php array_unique之后json_encode需要注意
php下尝试使用GraphicsMagick的缩略图功能
window+nginx+php环境配置 附配置搭配说明
PHPwind整合最土系统用户同步登录实现方法
Windows 下的 PHP-PEAR 安装方法
Notice: Undefined index: page in E:\PHP\test.php on line 14
ionCube 一款类似zend的PHP加密/解密工具
Godaddy空间Zend Optimizer升级方法
PHP中冒号、endif、endwhile、endfor使用介绍
PHP 开发环境配置(Zend Studio)
Zend framework处理一个http请求的流程分析
php遍历目录viewDir函数
©2014-2024 dbsqp.com