0

0

Yii框架控制器和模型的命名规范_2.0版本大小写规则【说明】

星夢妙者

星夢妙者

发布时间:2026-03-11 17:15:36

|

381人浏览过

|

来源于php中文网

原创

yii 2.0 命名规范要求控制器类名用 pascalcase + controller 后缀、文件名严格匹配类名并置于 @app/controllers/,模型类名 pascalcase 无后缀、文件名一致且放于 @app/models/,视图文件全小写连字符分隔;三者大小写各自独立又环环相扣。

yii框架控制器和模型的命名规范_2.0版本大小写规则【说明】

控制器类名必须用 PascalCase + Controller 后缀

Yii 2.0 的自动路由机制依赖类名严格匹配 URL 路径,SiteController 对应 /site/indexUserAdminController 对应 /user-admin/index。小写开头(如 siteController)或漏掉 Controller(如 Site)会导致 404 或 “Class not found” 错误。

常见错误现象:Invalid Parameter – yii\base\InvalidParamException 提示 “Unable to find ‘xxx’ controller”,其实只是类名没按规范命名。

  • 类文件必须放在 @app/controllers/ 下,且文件名 = 类名 + .php(如 SiteController.php
  • 类名中连字符(-)在 URL 中会转为驼峰,但控制器类名本身不能含连字符——User-Admin 是非法类名,必须写成 UserAdminController
  • 大小写敏感:Linux 环境下 sitecontroller.php(全小写)无法被自动加载,即使类定义是 class SiteController

模型类名必须用 PascalCase,不加后缀

模型类不强制要求后缀,但约定俗成用单数、PascalCase 形式,比如 UserUserProfileOrderItem。Yii 的 ActiveRecord 机制通过类名推导表名(Useruser),大小写错乱会直接导致查询报错或查不到数据。

使用场景:在控制器里调用 User::find()->one(),如果类名写成 useruserModel,PHP 会报 Class 'user' not found;若类名正确但文件名是 user.php(小写),在 Linux 下同样加载失败。

  • 模型文件放在 @app/models/,文件名必须与类名完全一致(User.php 对应 class User
  • 表名推导默认转为小写+下划线,UserProfileuser_profile;若实际表名是 userProfile,需在模型中重写 tableName() 返回 'userProfile'
  • 避免用数字开头(3rdPartyLog)或保留字(ArrayObject)作类名,PHP 解析会失败

视图文件名和路径必须全小写 + 连字符分隔

控制器动作渲染视图时,默认找 @app/views/控制器ID/动作ID.php,其中控制器 ID 和动作 ID 都是 URL 中的小写连字符格式,和类名无关。比如 UserAdminController::actionCreateUser() 对应视图路径是 @app/views/user-admin/create-user.php,不是 createUser.phpCreateUser.php

常见错误现象:页面空白或 View not found,但控制器和模型都没问题——八成是视图文件名用了驼峰或大小写混搭。

  • 控制器 ID 来自类名去掉 Controller 后按 PascalCase 拆分并转小写连字符:UserAdminControlleruser-admin
  • 动作 ID 是方法名去掉 action 前缀,首字母小写后按驼峰拆分:actionCreateUser()create-user
  • 视图文件扩展名必须是 .php,不能是 .html.twig(除非显式配置模板引擎)

命名冲突时优先服从自动加载规则,而非“看着顺眼”

Yii 2.0 的 ClassMap 和 PSR-4 自动加载器对大小写极其敏感,尤其在生产环境部署到 Linux 服务器时,Windows 下能跑的 user.php + class User 会直接挂掉。

性能影响很小,但兼容性风险极高:一次命名不一致,可能表现为开发环境正常、测试环境报错、线上 500,排查时容易绕远路去查数据库或中间件。

  • 统一用 vendor/bin/yii serve 在本地模拟 Unix 文件系统行为,提前暴露大小写问题
  • CI 流程中加入检查脚本,扫描 @app/controllers/@app/models/ 下文件名是否与类名完全一致(可用 grep "class " *.php | sed 's/class //; s/{.*//' 辅助比对)
  • 别为了“语义清晰”在类名里加下划线(User_Profile)或缩写(usr),Yii 不识别,PHP 也不认
事情说清了就结束。最常被忽略的是:类名、文件名、URL 路径三者大小写规则各自独立,但又环环相扣——改一个,另外两个往往得跟着动。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
什么是中间件
什么是中间件

中间件是一种软件组件,充当不兼容组件之间的桥梁,提供额外服务,例如集成异构系统、提供常用服务、提高应用程序性能,以及简化应用程序开发。想了解更多中间件的相关内容,可以阅读本专题下面的文章。

182

2024.05.11

Golang 中间件开发与微服务架构
Golang 中间件开发与微服务架构

本专题系统讲解 Golang 在微服务架构中的中间件开发,包括日志处理、限流与熔断、认证与授权、服务监控、API 网关设计等常见中间件功能的实现。通过实战项目,帮助开发者理解如何使用 Go 编写高效、可扩展的中间件组件,并在微服务环境中进行灵活部署与管理。

226

2025.12.18

class在c语言中的意思
class在c语言中的意思

在C语言中,"class" 是一个关键字,用于定义一个类。想了解更多class的相关内容,可以阅读本专题下面的文章。

870

2024.01.03

python中class的含义
python中class的含义

本专题整合了python中class的相关内容,阅读专题下面的文章了解更多详细内容。

30

2025.12.06

windows查看端口占用情况
windows查看端口占用情况

Windows端口可以认为是计算机与外界通讯交流的出入口。逻辑意义上的端口一般是指TCP/IP协议中的端口,端口号的范围从0到65535,比如用于浏览网页服务的80端口,用于FTP服务的21端口等等。怎么查看windows端口占用情况呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

1496

2023.07.26

查看端口占用情况windows
查看端口占用情况windows

端口占用是指与端口关联的软件占用端口而使得其他应用程序无法使用这些端口,端口占用问题是计算机系统编程领域的一个常见问题,端口占用的根本原因可能是操作系统的一些错误,服务器也可能会出现端口占用问题。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

1169

2023.07.27

windows照片无法显示
windows照片无法显示

当我们尝试打开一张图片时,可能会出现一个错误提示,提示说"Windows照片查看器无法显示此图片,因为计算机上的可用内存不足",本专题为大家提供windows照片无法显示相关的文章,帮助大家解决该问题。

835

2023.08.01

windows查看端口被占用的情况
windows查看端口被占用的情况

windows查看端口被占用的情况的方法:1、使用Windows自带的资源监视器;2、使用命令提示符查看端口信息;3、使用任务管理器查看占用端口的进程。本专题为大家提供windows查看端口被占用的情况的相关的文章、下载、课程内容,供大家免费下载体验。

462

2023.08.02

C# ASP.NET Core微服务架构与API网关实践
C# ASP.NET Core微服务架构与API网关实践

本专题围绕 C# 在现代后端架构中的微服务实践展开,系统讲解基于 ASP.NET Core 构建可扩展服务体系的核心方法。内容涵盖服务拆分策略、RESTful API 设计、服务间通信、API 网关统一入口管理以及服务治理机制。通过真实项目案例,帮助开发者掌握构建高可用微服务系统的关键技术,提高系统的可扩展性与维护效率。

3

2026.03.11

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号