选择Codeigniter作为PHP框架
这个标题只是个引子,虽然 PHP 很简单,能够快速进行开发,但是也有很多弊病,比如说由于缺乏有效的限制从而导致写出“坏”代码。那么如何解决这些弊病呢?使用 PHP 开发框架能很好的解决。
使用框架的根本好处就是提升生产力,比如开发效率、开发质量、可维护性等等。
PHP 框架有很多,选择合适的却不容易,这篇博文就简单说说框架,假如你是一个新手,希望能够帮助你。
框架的基本定义
一个应用程序框架一般是基于一种标准的框架结构、这种结构是你在写代码的时候必须遵守的,同时框架也提供了很多类库和工具,框架结构让你能够写出更规范的代码,而工具和类库让你能够提高开发速度。
一个框架一般使用 MVC 设计模式,设计模式很多也很难学,我更倾向称 MVC 是一种架构,同时 MVC 也比较容易理解(相对的)。
框架的基本功能
对于一个框架来说,功能应该包含基础性功能和功能性功能,基础性功能是精髓,主要是为了解决 WEB 开发中的核心问题,而功能性功能则是锦上添花,一般是解决特定问题的类库。
- 路由规则,路由规则是和代码的结构一一绑定的。
- 逻辑,模型,视图分离,这也是建立在 MVC 应用架构基础上的。
- 可扩展,框架不仅仅让你去业务代码,也可以由框架创造框架。
- 提供单元测试工具。
- 应用安全机制。
- 提供强大的日志功能,Debug 功能。
- 大量的类库包和工具,框架可以自由的引入第三方的类库包(比如 Composer)
框架的好处
那么框架是如何具体提高生产力的呢,归纳如下:
- 避免造轮子,在学习过程中造轮子是一种实践,在工作过程中造轮子不明智(大部分情况如此)。
- 节省时间,WEB 项目大部分逻辑可能是相同的(CRUD操作,Session管理,权限验证),假如不使用框架,就要不断的重复写,这是一种时间浪费。同时由于没有良好的规约,会经常性犯同样的错误。
- 标准化代码结构
代码目录结构如何组织?如何引用文件?对于这些事情,框架大部分提供了很好的规约,而你要做的就是去遵循,比如业务逻辑应该在控制层,数据层应该在模型层(针对 MVC 模式来说),良好的框架应该会强迫你去遵守,没有规则不成方圆。 - 代码,系统扩展性更好
代码能够在Windows上运行吗?代码能在所有 PHP 版本中运行吗?底层数据库从Mysql换成Sqlserver,代码还能运行吗?框架基本上能优雅的解决这些问题,让你专注于业务编写,排除其他的干扰(当然这样的干扰对学习很有帮助)。 - 系统更安全
谁也不能保证自己写的代码是完全安全的,而框架经过千锤百炼,提供了很好的代码保护(你甚至可能不知道如何是保护的),从结果上来说,框架会限制你的行为,会提供好的工作机制让代码更安全。 - 提高代码质量
框架能够让编写的代码更安全,更容易维护,更好读。 - 充分利用开源的力量
框架 80% 的部分提供了很多包(称为类库)和 工具,这些包和工具解决了很多复杂的问题,比如说快速通过这些包生成验证码,通过工具快速构建一个数据库表。这也说明了二点,你要尽可能的使用稳定的开源包,另外也避免了造轮子。
什么样的框架是好的
选择框架的标准很重要,每个人的编码能力,理解能力,工作特点,这些驱使你应该选择合适的框架,而不是最流行的框架。
- 要注意框架的执行速度,使用框架可能节省开发时间,但是带来部分性能和速度的损耗,这是需要平衡的。不过个人觉得性能的瓶颈不在框架,应该强调你的业务设计。
- 简单的,学习成本要低,PHP 本身很容易使用和学习,大部分框架使用了很多设计模式,但是对于大部分人来说强调的是快速编码,假如不是特别理解这个框架的设计,那么使用这个框架的成本就太高了,另外由于框架在 PHP 上做了过多的封装,那你面对的也许就不是 PHP 语言了,所以建议选用相对简单的框架,除非你有特殊需求。
- 良好的框架学习和使用文档,社区对这个框架的支持程度,对我来说就是中文文档有没有。
- 限制不要太多
很多框架会限制你很多编码方式,就是说不提倡使用原生的 PHP 功能,比如我学习Javascript的时候先学习的是JQuery,到最后分不清什么是 Javascript 语言了。一个框架应该是灵活的,限制太多会导致使用成本变高。 - 可扩展
一个框架应该是自由的,你可以使用这个框架最精华的部分,其他的部分(比如一些特定任务的类库)应该是可选的,同时这个框架还容易引入第三方优秀的库。
那为什么选择 Codeigniter
Codeigniter 给人初始的感觉太老了,其实这是一种误区,它支持大部分的 PHP 版本,虽然没有什么高级特性,但足够用了。
只要简单了解其 MVC 设计,包括常规的几个主题(路由,数据库,日志等)就基本上可以开发了,我花了半天的时间基本上就学会使用了。
Codeigniter 的文档也不错,看起来丝毫不费力。
Codeigniter 安装也很简单,将包拷贝下来放到虚拟主机上就能运行,想想 Laravel 的安装(不适合初学者)。
另外使用 Codeigniter 没有太多的约束,要是觉得某个功能不好用(吐槽其日志类库,将框架运行的信息和应用的信息混合在一块,等同鸡肋),可以随意使用第三方库。
其实最重要的还是简单,不管是使用还是学习。
假如你是一个初学者,为了让学习 PHP 过程更轻松可以选择它, 假如要快速开发可以选择它,假如要研究框架也可以选择它。