Zend Framework MVC アプリケーションのために推奨されるプロジェクト構造概要
たくさんの開発者が、比較的柔軟な環境でZend Frameworkプロジェクトのための
最善のプロジェクト構造のガイダンスを望みます。
「柔軟な」環境とは、
それらのアプリケーションを実行し、かつ安全にするための
最も理想的なプロジェクト構造を達成するために、
必要に応じてそれらのファイルシステムとウェブサーバ構成を開発者が操作できる
環境です。
デフォルトのプロジェクト構造では、
それらの配置で開発者がそのような柔軟性を持つと仮定します。
以下のディレクトリ構造は、
複雑なプロジェクトのために最大限に拡張可能に設計されています。
その一方で、プロジェクトのためのフォルダとファイルの単純なサブセットを
より単純な必要条件で提示します。
この構造も、モジュラー及び非モジュラー両方のZend Frameworkアプリケーションのために、
変更なしで動作します。
.htaccessファイルは、
この付録に含まれるリライト構成ガイド
で定めるウェブサーバでも、URLリライト機能を必要とします。
このプロジェクト構造で、可能性があるすべてのZend Frameworkプロジェクト条件を
サポートすることは意図していません。
Zend_Toolによって使われるデフォルトのプロジェクト・プロフィールは、
このプロジェクト構造を反映します。
しかし、この構造でサポートされない必要条件を持つアプリケーションでは、
カスタム・プロジェクト・プロフィールを使わなければなりません。
推奨されるプロジェクト・ディレクトリ構造/
application/
configs/
application.ini
controllers/
helpers/
forms/
layouts/
filters/
helpers/
scripts/
models/
modules/
services/
views/
filters/
helpers/
scripts/
Bootstrap.php
data/
cache/
indexes/
locales/
logs/
sessions/
uploads/
docs/
library/
public/
css/
images/
js/
.htaccess
index.php
scripts/
jobs/
build/
temp/
tests/
]]>
以下では、一覧に記載されたディレクトリ毎に利用例を記述します。
application/:
このディレクトリは、アプリケーションを含みます。
構成や利用されるサービス、及びブートストラップ・ファイルと同様に、
MVCシステムを収納します。
configs/:
アプリケーション全体の設定のディレクトリ
controllers/,
models/,
views/:
These directories
serve as the default controller, model or view directories. Having
these three directories inside the application directory provides the
best layout for starting a simple project as well as starting a modular
project that has global controllers/models/views.
controllers/helpers/: These
directories will contain action helpers. Action helpers will be
namespaced either as "Controller_Helper_" for
the default module or "<Module>_Controller_Helper" in other
modules.
layouts/: This layout
directory is for MCV-based layouts. Since
Zend_Layout is capable of
MVC- and non-MVC-based layouts,
the location of this directory reflects that layouts are not on a
1-to-1 relationship with controllers and are independent of templates
within views/.
modules/: Modules allow a
developer to group a set of related controllers into a logically
organized group. The structure under the modules directory would
resemble the structure under the application directory.
services/: This directory is
for your application specific web-service files that are provided by
your application, or for implementing a Service
Layer for your models.
Bootstrap.php: This file is
the entry point for your application, and should implement
Zend_Application_Bootstrap_Bootstrapper.
The purpose for this file is to bootstrap the application and make
components available to the application by initializing them.
data/: This directory provides a
place to store application data that is volatile and possibly temporary. The
disturbance of data in this directory might cause the application to fail.
Also, the information in this directory may or may not be committed to a
subversion repository. Examples of things in this directory are session files,
cache files, sqlite databases, logs and indexes.
docs/: This directory contains
documentation, either generated or directly authored.
library/: This directory is for
common libraries on which the application depends, and should be on the
PHP include_path. Developers should
place their application's library code under this directory in a unique
namespace, following the guidelines established in the PHP
manual's Userland Naming
Guide, as well as those established by Zend itself. This
directory may also include Zend Framework itself; if so, you would house it in
library/Zend/.
public/: This directory contains all
public files for your application. index.php sets up and
invokes Zend_Application, which in turn invokes the
application/Bootstrap.php file, resulting in dispatching
the front controller. The web root of your web server would typically be set to
this directory.
scripts/: This directory contains
maintenance and/or build scripts. Such scripts might include command line,
cron, or phing build scripts that are not executed at runtime but are part of
the correct functioning of the application.
temp/: The temp/
folder is set aside for transient application data. This information would not
typically be committed to the applications svn repository. If data under the
temp/ directory were deleted, the application should be
able to continue running with a possible decrease in performance until data is
once again restored or recached.
tests/: This directory contains
application tests. These could be hand-written, PHPUnit tests, Selenium-RC
based tests or based on some other testing framework. By default, library code
can be tested by mimicing the directory structure of your
library/ directory. Additionally, functional tests for
your application could be written mimicing the
application/ directory structure (including the
application subdirectory).
モジュール構造
The directory structure for modules should mimic that of the
application/ directory in the recommended project structure:
configs/
application.ini
controllers/
helpers/
forms/
layouts/
filters/
helpers/
scripts/
models/
services/
views/
filters/
helpers/
scripts/
Bootstrap.php
]]>
The purpose of these directories remains exactly the same as for the recommended
project directory structure.
リライト設定ガイド
URL rewriting is a common function of HTTP
servers. However, the rules and configuration differ widely between them. Below are
some common approaches across a variety of popular web servers available at the time of
writing.
Apache HTTPサーバ
All examples that follow use mod_rewrite, an official
module that comes bundled with Apache. To use it,
mod_rewrite must either be included at compile time or
enabled as a Dynamic Shared Object (DSO). Please consult the
Apache documentation for your
version for more information.
バーチャルホスト内でのリライト
Here is a very basic virtual host definition. These rules direct all requests
to index.php, except when a matching file is found under
the document_root.
ServerName my.domain.com
DocumentRoot /path/to/server/root/my.domain.com/public
RewriteEngine off
RewriteEngine On
RewriteCond %{REQUEST_FILENAME} -s [OR]
RewriteCond %{REQUEST_FILENAME} -l [OR]
RewriteCond %{REQUEST_FILENAME} -d
RewriteRule ^.*$ - [NC,L]
RewriteRule ^.*$ /index.php [NC,L]
]]>
Note the slash ("/") prefixing index.php; the rules for
.htaccess differ in this regard.
.htaccessファイル内でのリライト
下記はmod_rewriteを利用する
.htaccessファイルの例です。
It is similar to the virtual host
configuration, except that it specifies only the rewrite rules, and the leading
slash is omitted from index.php.
mod_rewriteを設定する方法はたくさんあります。
もし、詳細をお好みでしたら、Jayson Minard のBlueprint for PHP Applications:
Bootstrappingをご覧下さい。
Microsoft Internet Information サーバ
As of version 7.0, IIS now ships with a standard rewrite engine.
You may use the following configuration to create the appropriate rewrite rules.
]]>