MVC 的目录结构

2022-08-30 22:55:56

我正在尝试清理我一直在研究的框架。目前,该网站由以下目录组成:

Models
Views
Controllers
Helpers (Miscellaneous functions)
Libraries (Universal classes, like library and session management)
Images
Style

每当调用页面时,路由器脚本都会查找关联的控制器,因此 thesite.com/login 会在“/controllers/login.php”处实例化Login_Controller我面临的问题是,路由器脚本本身感觉就像一种控制器,view.php也是如此,它处理要由相应视图处理的格式数据。但这些不太像页面控制器,因为它们控制MVC本身。我对这个架构还是有点陌生的,我很好奇有更多经验的人会如何组织这个架构。

我可以将路由器和视图控制器分类为库,还是在/控制器中创建一个名为“pages”的子目录或任何其他想法会更好?非常感谢。


答案 1

我建议你研究一个框架的目录结构,比如symfony2或yii。

这是我为我选择的:

public_html/              (for public files) (should be public, place only index.php in here)
public_html/css/
public_html/images
public_html/js            (for your js files, or custom generated ones)
lib/                      (for my libs)  (should be private)
lib/vendor/               (for 3rd party libs)
application/              (for the whole app) (should be private)
application/class         (classes that make the app work such as mainApp, Controller, Model, View, etc...)
application/class/model   (all the models)
application/class/view    (all the views)
application/class/view/html (templates used by the views)
application/class/controller (all controllers)
application/class/helper  (helper functions)
application/class/lib     (libs that you develop for the application)
application/template      (layout and/or templates for the application)
application/conf          (config files)
application/log           (log files)
application/cron          (scheduled jobs)
application/database      (for database migration scripts)
...

您还可以使用文件命名约定,例如:YourClassName.class.php用于 clases,YourView.phtml 用于视图等。检查一个框架,你将学习如何很好地构建和应用程序。


答案 2

我建议遵循Symfony 1.x目录结构。清晰、合乎逻辑、安全。

摘自Fabien Potencier和François Zaninotto的“The Definitive guide to Symfony”一书:

apps/
  frontend/
  backend/
cache/
config/
data/
  sql/
doc/
lib/
  model/
log/
plugins/
test/
  bootstrap/
  unit/
  functional/
web/
  css/
  images/
  js/
  uploads/
  • 应用/包含项目的每个应用程序(通常是前台和后台的前端和后端)的一个目录。
  • 缓存/包含配置的缓存版本,以及(如果激活它)项目的操作和模板的缓存版本。缓存机制(详见第12章)使用这些文件来加快对Web请求的响应速度。每个应用程序在这里都有一个子目录,其中包含预处理的PHP和HTML文件。
  • 配置/保存项目的常规配置。
  • 数据/在这里,您可以存储项目的数据文件,如数据库架构、创建表的 SQL 文件,甚至是 SQLite 数据库文件。
  • 文档/存储项目文档,包括您自己的文档和 PHPdoc 生成的文档。
  • lib/专用于外部类或库。在这里,您可以添加需要在应用程序之间共享的代码。model/子目录存储项目的对象模型(如第8章中所述)。
  • 日志/存储由 symfony 直接生成的适用日志文件。它还可以包含 Web 服务器日志文件、数据库日志文件或来自项目任何部分的日志文件。Symfony 为每个应用程序和每个环境创建一个日志文件(日志文件在第 16 章中讨论)。
  • 插件/存储应用程序中安装的插件(插件在第 17 章中讨论)。
  • 测试/包含用PHP编写的单元和功能测试,并与symfony测试框架兼容(在第15章中讨论)。在项目设置过程中,symfony 会自动添加一些存根,并进行一些基本测试。
  • 网站/Web 服务器的根目录。唯一可以从互联网访问的文件是位于此目录中的文件。

推荐