`
dcj3sjt126com
  • 浏览: 1871038 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

CakePHP2命名规范

    博客分类:
  • PHP
阅读更多

 

CakePHP的命名规范相当重要,遵循CakePHP框架的命名规范,可以获得框架内置的各种功能。CakePHP2发布之后,命名规范这块与老的框架没有任何区别,本文同时适用于CakePHP 2.x和CakePHP 1.x框架。

总得来说,文件名使用下划线,类名用驼峰命名法。比如,MyNiftyClass类对应的文件名就是my_nifty_class.php。下面是不同类型的类和其相对应的文件命名方式的一些例子,

控制器类KissesAndHugsController,可以在kisses_and_hugs_controller.php文件中找到(注意文件名中的_controller)。

组件类MyHandyComponent,可以在my_handy.php文件中找到。

模型类OptionValue可以在option_value.php文件中找到。

行为类EspeciallyFunkableBehavior,可以在especially_funkable.php文件中找到。

视图类SuperSimpleView,可以在super_simple.php文件中找到。

助手类BestEverHelper,可以在best_ever.php文件中找到。

上述的每个文件都存放在相应的文件夹中。

总结:类名中,除了模型类,都需要在类命中标明该类的身份,比如Controller,Component,Behavior等。文件名中,只有控制器类需要标明身份,即在文件末尾加上_controller.

模型和数据库命名规范

模型类名使用单数驼峰命名法,Person,BigPerson以及ReallyBigPerson都是约定的模型命名。

表名使用复数和下划线命名。与上述模型相对应的表名分别是people,big_people和really_big_people。

可以使用“inflector”库检查单词的单复数形式。

包含两个或更多单词的字段名,以下划线命名,比如first_name。

在hasMany,belongsTo,hasOne关系中,外键默认由相关表加_id表示。举例来说,一个Baker和Cake之间的关系是一对多,那么在cakes表中会存在一个baker_id外键来关联bakers表(注意,这里的关联外键是单数)。对于多个单词组成的表名,像category_types,外键会事category_type_id。即表名虽然是复数,但是在其它表中存在的该表外键,要以单数形式命名。

多对多关系中一般会存在一个链接表,该链接表字段的一个命名方式是需要以单词首字母字母顺序排列,例如apples和zebras两张表,在链接表中,他们应该是apples_zebras,而非zebras_apples。

所有CakePHP模型交互的表,都需要唯一的主键来标示每一行数据。CakePHP不支持组合主键,如果你想直接操作链接表数据,可以直接使用SQL语句。

除了使用递增字段作为主键之外,还可以使用char(36)作为主键。在使用odel::save方法保存记录时,CakePHP会自动识别该字段,并使用(String::uuid)生成一个36位的字符串作为唯一主键。

控制器命名规范

控制器类名使用复数驼峰命名法,并且以Controller结尾。PeopleController以及LatestArticlesControlle都是合法的控制器命名方式。

控制器中的首个方法应该是index()方法,当请求只指定了控制器,没有动作方法时,CakePHP默认执行该控制器的index()方法。

通过在控制器方法名之前加一个下划线,可以更改该控制器方法的可见范围。如果控制器方法前有一个下划线,这个方法就只能在内部使用,而无法通过浏览器访问。

控制器类名与URL地址

单个单词的控制器能够非常容易的被映射到小写的URL地址上。例如,ApplesController可以通过http://example.com/apples访问。

多词控制器的访问地址,可以是该控制器名的任何曲折形式。

  • /redApples
  • /RedApples
  • /Red_apples
  • /red_apples

都能指向到RedApples控制器的index方法。不过,命名约定规定,url地址应该是小写单词加下划线组成。因此,/red_apples/go_pick是请求RedApplesController::go_pick方法的正确形式。

视图命名规范

视图模板文件通过调用他们的控制器方法命名,以下划线分隔多词。PeopleController类中得getReady()方法,会自动关联/app/views/people/get_ready.ctp视图模板。

命名方式就是/app/views/<controller name>/<underscored_function_name>.ctp。

总结

数据库表名:people
模型类:person,路径app/models/person.php
控制器类:PeopleController,路径app/contollers/people_controller.php
视图类:app/views/people/index.ctp

使用这种命名约定,CakePHP能够将http://example.com/people/映射到PeopleController控制器的index()方法,Person模型可以直接在该控制器中使用,并且该模型会自动与people表绑定,然后输出视图。所有这一些不需要配置,只要你遵守CakePHP的命名约定即可。

分享到:
评论

相关推荐

    CakePHP 3.4 开发手册文档 CakePHP Cookbook Documentation Release 3.4

    - **连接路由**:详细解释了如何定义路由规则,以及如何利用这些规则将 URL 映射到特定的控制器和动作。 - **RESTful 路由**:探讨了如何创建符合 RESTful 风格的 URL,并将其映射到相应的控制器动作。 - **生成 URL...

    cakephp 框架

    1. 约定优于配置:CakePHP 设定了许多默认约定,如目录结构、命名规范等,降低了项目初始化的复杂度。 2. 快速开发:框架提供了丰富的内置功能,如路由、认证、授权、错误处理和日志记录,使开发者能快速构建功能...

    cakephp最新开发文档

    14. **命名约定**:CakePHP遵循一套严格的命名规则,如CamelCase(驼峰命名)和下划线命名,以保持代码的一致性。 15. **数据库交互**:CakePHP支持多种数据库系统,并提供了简洁的查询构造器,方便编写SQL语句。 ...

    CakePHP路由

    3. **作为命名参数**:如果在路由定义时指定了参数名,则可以通过 `$this-&gt;request-&gt;getParam('name')` 获取。 ```php $routes-&gt;connect('tests/:arg1/:arg2', ['controller' =&gt; 'Tests', 'action' =&gt; 'index'], ...

    CakePHP 3.5 开发手册文档 CakePHP Cookbook Documentation Release 3.5/共900页 PDF

    - **3.0 Migration Guide**: 从旧版本迁移到 CakePHP 3.0 版本的指导,涵盖了安装配置、命名空间调整、配置选项、新 ORM 系统等内容。 - **Requirements**: 迁移所需的最低系统要求。 - **Upgrade Tool**: 提供了...

    cakePHP完整实例

    表结构的设计应当遵循一定的命名规范,以便于后续与CakePHP框架的对接。 - **模型(Model)**:创建模型类来表示`tasks`表的数据结构,模型负责处理与数据库的交互逻辑,如数据验证、查询、更新等。 - **控制器...

    cakephp中文手册.pdf

    这意味着,如果模型类名与数据库表名遵循一定的命名规则,框架就能自动识别并建立关联。 **CakePHP 目录结构** 解压 CakePHP 后,你会看到三个主要目录: 1. **app**:包含了你的应用程序代码。这个目录下有子...

    cakephp手册单页完整版

    CakePHP遵循一定的命名约定,这有助于保持代码的一致性和可维护性。 1. **类名**:采用驼峰式命名法,如`ArticleController`。 2. **方法名**:采用小写字母加下划线分隔,如`add_article()`。 3. **变量名**:同样...

    cakephp

    CakePHP有一套严格的命名规则,这有助于保持代码的一致性和可读性。例如,控制器文件应命名为`&lt;controller_name&gt;Controller.php`,模型文件应命名为`&lt;model_name&gt;.php`,而视图文件则应命名为`&lt;view_name&gt;.ctp`。 #...

    packtpub.CakePHP.1.3.Application.Development.Cookbook.Mar.2011

    学习 CakePHP 的命名规范和目录结构,以便更好地遵循框架的最佳实践。 7. **组件与行为**:探索 CakePHP 的组件(Component)和行为(Behavior)系统,了解如何编写自定义组件来扩展框架功能,以及如何利用行为来...

    cakephp1.3.11

    例如,数据库连接、模型和控制器的命名规则等都有预设的约定,使得开发者无需过多地进行配置,从而节省了大量时间。 在安全性方面,CakePHP 1.3.11包含了防止SQL注入和XSS攻击的机制。其内置的ORM(对象关系映射)...

    CakePHP入门翻译手册(序)

    - **遵循约定优于配置**:CakePHP有默认的约定,如文件结构和命名规范,减少了需要大量配置的情况。 - **丰富的社区和文档**:作为一个成熟的开源项目,CakePHP拥有活跃的社区和详尽的文档,为开发者提供丰富的资源...

    基于PHP的CakePHP(PHP的框架).zip

    5. **烤饼模式(Cake Pattern)**:这是一种约定优于配置的方式,通过预定义的文件结构和命名规范,使得开发更快速,因为开发者不需要花费大量时间在配置上。 6. ** Bake 工具**:Bake是CakePHP内置的命令行工具,...

    PHP实例开发源码—CakePHP(PHP的框架).zip

    5. **遵循约定优于配置**:CakePHP遵循一定的命名约定,减少手动配置,让开发者可以专注于编写业务逻辑。 ** 使用须知.txt ** 在使用这个PHP实例开发源码时,你需要了解以下几点: 1. **环境要求**:确保你的...

    CakePHP框架Model关联对象用法分析

    遵循 CakePHP 的命名规则非常重要,因为框架会根据这些规则自动推断关联和外键。例如,单数形式的模型名加上 `_id` 通常作为外键,模型名的复数形式作为表名,而模型类名则遵循驼峰式命名。 在实际开发中,通过这些...

    cakphp15分钟建博客

    注意:表名和字段名称的选择应当遵循CakePHP的命名规则(《CakePHP规则》),这样可以使得许多功能无需额外配置即可使用。 #### 五、配置数据库连接 1. **复制默认配置文件**:在`/app/config`目录下,找到`...

    Cakephp 执行主要流程

    接着,cake/lib/inflector.php处理了字符串的单复数转换、命名规则等,这是对数据进行格式化的重要一步。cake/lib/configure.php提供了文件配置的读写、路径设置以及加载文件的方法,它对于配置管理和路径处理至关...

    cake-php:使用CakePHP进行实验

    **蛋糕PHP:深入理解并使用CakePHP进行Web开发** CakePHP是一个基于Model-View-Controller (MVC)架构模式的...在实际项目中,结合良好的编码规范和设计模式,将能充分利用CakePHP的优势,实现高质量的Web解决方案。

    PHP编码规范(中文版)

    - Larry Masters: CakePHP, CakePHP2 - John Mertic: SugarCRM - Taylor Otwell: Laravel - Ryan Parman: Amazon Web Services SDK - Evert Pot: SabreDAV - Fabien Potencier: Symfony, Symfony2 - Mike van Riel: ...

    CakeFianl.zip

    【标题】"CakePHP框架学习资源包" 【描述】"CakeFianl.zip"是一个包含有关CakePHP框架的综合学习资源。CakePHP是一款基于MVC(Model-View-...建议按照文件的结构和命名规范逐一学习,逐步掌握这个强大的PHP框架。

Global site tag (gtag.js) - Google Analytics