合理的PHP项目结构提升开发效率与可维护性,典型结构包含app、config、public、vendor等目录,遵循MVC分层,通过public/index.php统一入口,结合Composer自动加载、环境配置分离与安全权限控制,确保代码清晰、安全、易扩展。

PHP项目结构的设计直接影响开发效率、维护成本和团队协作。合理的目录结构能让代码更清晰,功能划分更明确,也便于后期扩展。以下是一些常见的设计思路和推荐结构。
1. 基础项目结构
一个典型的PHP项目通常包含以下几个核心目录:
- /app:存放应用的核心逻辑,如控制器、模型、服务类等。
- /config:配置文件目录,包括数据库、路由、环境变量等。
- /public:Web根目录,只允许访问该目录下的文件(如index.php、静态资源)。
- /src:可选,用于存放自定义类库或组件(在Composer项目中常见)。
- /vendor:由Composer管理的第三方依赖库。
- /tests:单元测试和功能测试代码。
- /logs:日志文件存储目录。
- /storage:缓存、会话、上传文件等运行时数据。
- /views 或 /templates:模板文件,前端展示层。
/project-root │ ├── app/ │ ├── Controllers/ │ ├── Models/ │ └── Services/ ├── config/ │ ├── database.php │ └── routes.php ├── public/ │ ├── index.php │ └── assets/ ├── storage/ │ ├── cache/ │ ├── sessions/ │ └── uploads/ ├── tests/ ├── vendor/ ├── views/ └── composer.json
2. 分层架构设计
采用MVC(Model-View-Controller)或其他分层模式能提升项目的可维护性。
- Model层:处理数据逻辑,与数据库交互,可使用Eloquent、PDO封装等。
- View层:负责页面渲染,建议使用模板引擎(如Twig、Blade)分离逻辑与展示。
- Controller层:接收请求,调用模型处理数据,返回视图或JSON响应。
对于复杂项目,还可以引入Service层来封装业务逻辑,避免控制器过于臃肿。
立即学习“PHP免费学习笔记(深入)”;
3. 路由与入口文件控制
所有HTTP请求应统一通过public/index.php入口进入,实现URL重写和安全隔离。
- 在
.htaccess或Nginx配置中设置重写规则,隐藏index.php。 - 入口文件加载自动加载器(autoload)、配置文件,并启动路由调度。
4. 配置与环境管理
不同环境(开发、测试、生产)应使用不同的配置。
- 使用
.env文件管理环境变量(可通过vlucas/phpdotenv读取)。 - 配置文件根据环境动态加载,避免硬编码敏感信息。
5. 自动加载与命名空间
使用Composer进行类的自动加载,规范命名空间。
- 在
composer.json中定义PSR-4自动加载规则,例如:"App\\": "app/" - 文件命名遵循驼峰式或下划线命名法,类名与文件名一致。
6. 安全与权限控制
合理设置目录权限,防止敏感目录被直接访问。
-
/app、/config、/storage等目录禁止Web直接访问。 -
public/以外的PHP文件不应暴露在Web服务器路径下。 - 上传目录禁止执行PHP脚本。











