Laravel 和 Yii 是当前两种针对 PHP 的优秀框架。它们在全球都有成熟的社区、以及大量的编程爱好者。本文为您全面比较 Laravel 和 Yii,并和您讨论如何根据具体项目在两者中做出选择。

译者 | 陈峻

如果您向任何经验丰富的Web应用开发人员询问,什么是他们首选的编程语言的话,他们的回答居多会提到PHP。的确,PHP是一种被广泛使用的通用脚本语言,特别适用于Web开发,并且可以被嵌入到HTML中。

根据网站技术分析工具Builtwith的统计,目前有3,090,319个实时网站仍在使用着PHP。当然,在开发低延迟、高稳定性的大型项目时,开发人员往往倾向于使用某种框架。其中,Laravel和Yii是当前两种针对PHP的优秀框架。它们在全球都有成熟的社区、以及大量的编程爱好者。下面,我为您全面比较Laravel和Yii,并和您讨论如何根据具体项目在两者中做出选择。

一、到底什么是Laravel和Yii?

Laravel是一个简单的PHP框架,经常被用于基于Web或Web应用的开发,最初是作为Codeigniter的更好替代品而创建的。它以支持MVC、协同ORM系统、可靠性、模块化、以及简单的编程规则而闻名。总的说来,Laravel框架具有如下关键特性:

  • Artisan:Artisan是一个命令行工具,可以让您轻松地创建模型、控件、计划任务、以及运行各种自定义的命令。

  • Eloquent:Eloquent是一个对象关系映射(Object-Relational Mapping,ORM)型数据库的交互式框架。

  • 不同的数据库支持:Laravel为当前可访问的每一种数据库格式提供了代码包。它通过允许迁移操作,来保证数据库的修改和版本控制。

  • Blade Template Engine:它允许在视图中使用简单的PHP代码。为了避免应用的过载,视图一旦被构建和缓存,就会被保持,直至它们被再次更新。

  • Vast Laravel Libraries:开发人员可以在自己的应用程序中,安全地使用数百个标准化的Laravel代码库。该框架的设计者还提供了定期更新的官方文档,以便开发者进行广泛地使用。

Yii是2006年作为PRADO框架的继承者被发布的。作为一个可被用于快速开发现代化Web应用的开源式PHP框架,它具有基于组件的架构和完整、可靠的缓存支持。开发人员可以使用Yii框架,去构建诸如:论坛、门户、内容管理系统、RESTful服务、以及电商网站等各种Web应用。总的说来,Yii框架具有如下关键特性:

  1. 全面支持DBMS:Yii框架支持PostgreSQL、MySQL、SQLite、Oracle、以及其他DBMS。

  2. 支持第三方模板引擎:Yii框架没有内置的模板引擎支持,但是可以使用第三方的解决方案。

  3. 强大的知识库:其官方文档和丰富的教程可以帮助开发人员快速地找到大部分问题的答案。

  4. 自动化代码生成:开发人员可以通过使用Gii的扩展,来自动生成代码,从而显著地加快编程的进程。

可见,这两个框架都是非常棒的Web开发的框架。当然,它们也有着本质上的不同。

二、Laravel与Yii之间的不同之处

1.安装

这两种框架都可以运行在PHP 5.4或更高的版本上。不过,Laravel需要诸如:PHP JSON和MCrypt PHP等额外的扩展,而Yii已经内置了它们。此外,您可以通过下载压缩文件,并将其解压缩到Web应用可以拿到的文件夹中,来安装Yii。同时,您还可以使用Composer(一种PHP 包管理工具 )来安装它,并配置访问令牌。而对于Laravel来说,您可以使用Laravel Installer或Composer来安装它。

得分:Laravel得1分:Yii得1分

2.基于场景的验证

Laravel没有任何可用于执行基于场景验证的代码包。而在Yii框架中,用户可以使用各种请求参数来分配模型,并对其进行验证。

得分:Laravel得1分:Yii得2分

3.客户端验证

Laravel并没有任何代码包可执行客户端的验证。而Yii由于提供了开箱即用的JavaScript验证,因此它允许您通过只定义一组模型规则,以用于在服务器端和客户端进行验证。

得分:Laravel得1分:Yii得3分

4.路由功能

Laravel虽然提供了资源路由(resource routing),但是您需要为所有控制器中的每一项操作,去声明一条路由。而Yii框架的默认选择便是逐个路由操作的模式,因此您无需进行反复操作,仅凭一个简单的路由即可。

得分:Laravel得1分:Yii得4分

5.CRUD(增加(Create)、检索(Retrieve)、更新(Update)和删除(Delete))的生成

许多项目会使用管理面板,来实现各种数据表的CRUD功能。而作为Yii中的一个专用扩展,Gii提供了一个基于Web的界面,可以自动生成各种常用的交互式代码片段。不过Laravel并不能默认支持CRUD的生成。

得分:Laravel得1分:Yii得5分

6.扩展支持

通过不同的扩展,我们往往能够让原有的框架,具有增强应用性能或特性的高级能力。虽然这两种框架都提供了受支持的扩展库,但是Laravel在此方面略显优势。目前,Yii有大约2,800个扩展。而Laravel已经能够支持大约9,000个扩展了。

得分:Laravel得5分:Yii得2分

7.迁移

您可能需要将应用迁移到新的数据库结构中,而不想丢失旧的结构中的数据。那么,这往往离不开便利的数据库迁移框架。由于Laravel提供了seeder来协助简化该过程,因此其迁移操作相对比较容易。而Yii也提供了一个完整的迁移工具,来支持有效的迁移过程。

得分:Laravel得3分:Yii得6分

8.测试

众所周知,在被用于Web应用的开发时,框架应当具有良好的测试能力,以检测和调试各项操作中的错误。同样,这两个框架在测试方面也是各有千秋。Yii提供了开箱即用的PHPUnit和Codeception,而Laravel提供了PHPUnit、以及诸如Httpkernel、DomCrawler、Browserkit等各种Symfony测试组件。

得分:Laravel得4分:Yii得7分

9.安全

如今,安全性对于应用程序来说已是至关重要的了,毕竟任何攻击或漏洞都可能造成严重的破坏,进而泄露有价值的客户信息。因此,您需要通过框架,来保护用户数据的同时,为各种用户角色提供和管理适当的访问级别。Yii和Laravel都提供了诸如:密码保护、身份验证、防止SQL注入、预防跨站点脚本(XSS)攻击、以及其他安全威胁机制。不过,由于Yii提供了功能丰富且基于角色的访问控制系统,而Laravel则需要第三方的扩展,因此Yii又更胜一筹。当然,我们在此并没有贬低Laravel的安全性价值的意思。

得分:Laravel得4分:Yii得8分

10.可用的文档

Laravel虽然提供了大量条理性强且具有技术含量的文档,然而由于信息量过大,开发人员很难快速地找到所要的信息。相比之下,Yii虽然没有强大的文档,但是在提供信息的方式上,并不存在陡峭的学习曲线。用户可以按照其文档指引,轻松地开始编程工作。当然,不可否认的是,就文档的丰富程度而言,Laravel要比Yii强大得多。

得分:Laravel得8分:Yii得5分

三、对比结果

从综合评分来看,Laravel和Yii可谓势均力敌、不分伯仲。毕竟每一种框架都有着适合自己的用例场景和具体领域。总的说来,Laravel是一个广受专注的框架,其主要用户群体是各类Web开发人员。当然,Yii也拥有不小的用户群,它主要适合那些初学者级别的Web开发人员、系统管理员、以及其他开发爱好者。

就实际项目而言,如果您正在尝试着构建大型的Web应用或企业级应用的话,Laravel将是您的最佳选择。而如果您正在寻找一个简单的开发框架,且目标是开发一个中小型应用的话,那么Yii会更加适合您。

原文链接:https://dzone.com/articles/differences-between-laravel-and-yii

译者介绍

陈峻 (Julian Chen),51CTO社区编辑,具有十多年的IT项目实施经验,善于对内外部资源与风险实施管控,专注传播网络与信息安全知识与经验;持续以博文、专题和译文等形式,分享前沿技术与新知;经常以线上、线下等方式,开展信息安全类培训与授课。