为什么我们要选择yii框架

为什么我们要选择yii框架

背景介绍:

SitePoint曾发表过一篇文章,着重强调了一些顶级的PHP框架,当时并列排名第四的是Yii(发音Yee)框架,最新版本为1.1.14。最近,Yii发布了2.0版本。

(推荐教程:yii

然而我们对它进行报导的时候,它还处在RC状态,如今刚好完整新版本发布,我觉得是时候重新考虑一下选择它的因素了。

选择yii框架的七大理由:

1、安装简单

对Web开发者来说,时间就是金钱。没有人会希望把自己的时间浪费在繁琐的安装和配置上。

Composer会来处理安装程序。那如果你想要一个安装过程的描述,Sitepoint最近发表了一篇关于此的文章,你可以参阅以下。而我比较喜欢倾向于使用基本的应用模板,哪怕我的站点上有一个单独的前端和后端组件。相反,我选择在我站点的后端部分使用一个模块。(Yii模块是迷你应用程序的最佳写照,用来嵌入到你的主应用程序中。)

注:后面的很多例子中的目录引用都使用到了简单模板的目录结构。

2、使用现代技术

Yii是一个纯粹的OOP框架,它充分利用了PHP一些较先进的功能,包括延迟静态绑定,SPL类和接口,以及匿名函数。

所有的类都被称为命名空间,并允许你利用它们的PSR-4兼容的自动加载机。也就是说,包括Yii中的HTML辅助类,也是同样如此简单:

use yiihelpersHtml;

Yii还可以定义别名,来帮助简化你的命名空间。在上面的例子中,use声明会加载一个类定义,目录中的默认路径为 /vendor/yiisoft/yii2/helpers。这个别名被定义在BaseYii类中第79行:

public static $aliases = ['@yii' => __DIR__];

该框架本身是使用Composer安装的,和它的扩展一样。发布扩展的程序甚至和创建composer.json一样简单,在Github上托管你的代码,并在Packagist上列出扩展。Yii还可以定义别名,来帮助简化你的命名空间。在上面的例子中,use声明会加载一个类定义,目录中的默认路径为 /vendor/yiisoft/yii2/helpers。这个别名被定义在BaseYii类中第79行:

3、高度的可扩展性

Yii就像一套西装,看起来很大,但其实却很容易调整来满足你的需求。实际上,框架的每个组件都是可扩展的。举一个简单的例子就是,在你的观点上增加了一个独特的body ID。(如果想知道你为什么想这样做,可以查看此文章)

首先,我会在我的appcomponents中创建一个名为View.php的文件,并添加以下内容:

namespaceappcomponents; classView extendsyiiwebView {     public$bodyId;     /* Yii allows you to add magic getter methods by prefacing method names with "get" */     publicfunction getBodyIdAttribute() {        return($this->bodyId !='') ?'id="' . $this->bodyId .'"' : '';    } }

然后,在我的主布局文件(appviewslayoutsmain.php)中,我想在HTML的body标签中补充以下内容:
<body BodyIdAttribute?>>

最后,我想在主配置文件中添加如下内容,让Yii可以使用扩展的View类,而不是默认的:

return[    // ...    'components'=> [        // ...        'view'=> [            'class'=> 'appcomponentsView'        ]      ]];

4、鼓励测试

Yii与Codeception是紧密相连的。Codeception是一个了不起的PHP测试框架,有助于简化应用创建部件、功能测试和验收测试的过程。因为你写的所有应用均是自动化测试,对吧?

测试过程中,Codeception扩展会使配置应用程序变得更简单。只需简单提供/tests/_config.php文件,即可配置你的测试程序。例如:

return[    'components'=> [        'mail'=> [            'useFileTransport'=> true,        ],        'urlManager'=> [            'showScriptName'=> true,        ],        'db'=> [                'dsn'=> 'mysql:host=localhost;dbname=mysqldb_test',        ],    ],];

使用该配置,将会发生如下几种情况:

1、 在功能测试和验收测试期间发送的任何一封邮件,将会被写入一个文件中,而不是被发送。使用该配置,将会发生如下这种情况:

2、 在你测试中的URLs将会采取这种格式: index.php/controller/action 而不是这种:/controller/action

3、 测试将会使用你的测试数据库,而不是你的产品数据库。

存在Yii框架中的特殊模块,同样也存在Codeception内。它TestGuy类中增加了几个方法,协助你在功能测试中的活动记录(Yii中的ORM)。举例来说,如果你想看看是否成功创建了一个用户名为“testuser”的新user,你可以做以下几点:

$I->amOnPage('register');$I->fillField('username','testuser');$I->fillField('password','qwerty');$I->click('Register');$I->seeRecord('appmodelsUser',array('name'=> 'testuser'));

5、简化安全性

安全性是任何一个web应用的重要组成部分,幸运的是,Yii有一些很棒的功能可以帮你解决这方面的烦恼。
Yii带有一个安全应用组件,其中公开的几个方法可以帮助创建一个更安全的应用。其中一些比较有用的方法如下:

·generatePasswordHash: 从一个密码和随机因子生成一个安全的单向散列函数。这种方法为你编译了一个随机因子,然后通过PHP crypt函数功能提供的字符串创建了一个单项散列函数。

·validatePassword:对于generatePasswordHash,这是一个伴侣功能,并且允许你检查用户提供的密码是否与你存储的散列函数相匹配。

·generateRandomKey:允许你创建一个任意长度的随机字符串。

Yii会对所有不安全的HTTP请求方法(PUT,POST,DELETE)进行自动检查,当你使用ActiveForm::begin()方法创建开放表单标签时,它会生成并输出一个token。通过编辑你的主配置文件可以禁止此功能,方法如下:

return[    'components'=> [        'request'=> [            'enableCsrfValidation'=> false,        ]];

为了防止XSS,Yii提供了一个叫HtmlPurifier的辅助类。这个类有一个名为process的静态方法,并且会使用popular filter library过滤出同名的输出库。

Yii还包括备用类,用来进行用户身份验证和授权。授权分为两种类型:ACF(访问控制过滤器)和RBAC(基于角色的访问控制)。

知我AI 知我AI

一款多端AI知识助理,通过一键生成播客/视频/文档/网页文章摘要、思维导图,提高个人知识获取效率;自动存储知识,通过与知识库聊天,提高知识利用效率。

知我AI 26 查看详情 知我AI

这两种授权方法,较简单的要数ACF了,它是通过在你的控制器中添加以下行为方法来实现的:

useyiifiltersAccessControl; classDefaultController extendsController {    // ...    publicfunction behaviors() {        return[            // ...            'class'=> AccessControl::className(),            'only'=> ['create','login','view'],                'rules'=> [                [                    'allow'=> true,                    'actions'=> ['login','view'],                    'roles'=> ['?']                ],                [                    'allow'=> true,                    'actions'=> ['create'],                    'roles'=> ['@']                ]            ]        ];    }    // ...}

上面的代码用于区分DefaultControllerto,允许guest用户的访问login 和view行为,而不是create 行为。(? 是一个匿名用户别名,@ 指的是已认证用户)。

RBAC是指那些用户可以在整个应用中执行特定操作行为的更有效的方法。包括为用户创建角色,定义app权限,然后使这些权限试用于相应的角色。如果你想创建一个Moderator的角色,并允许分配给该角色的所有用户批准文章。

你也可以使用RBAC定义角色,它允许你在特定条件下,授权访问应用的某些方面的自定义规则。例如,你可以创建一个规则,即允许用户编辑自己的文章,而不是那些其他人创建的。

6、缩短开发时间

大多数项目都会涉及一定的重复任务,没有人愿意浪费时间。而Yii提供的一些工具可以帮助你减少在这些任务中所花费的时间,将更多的时间用于定制让客户满意的应用。

在这些工具中,其中有一个名为“Gii”的工具最为强大。Gii是一个基于web的基架代码工具,可以让你快速创建代码模板:

·模型

·控制器

·形式

·模块

·扩展

·CRUD控制器行为和视图

Gii是高度可配置的。你可以将其设置为仅在特定的环境下加载。只需简单编辑下你的web配置文件即可,方法如下:

if (YII_ENV_DEV) {    // ...    $config['modules']['gii'] = [        'class' => 'yiigiiModule',        'allowedIPs' => ['127.0.0.1', '::1']    ]}

这样就可以确保党Yii的环境设置为开发的时候,Gii仅支持加载,并且它只通过本地主机访问时才会加载。

现在,让我们来看下模型生成器吧:

cd312d499ba0879addadc383d139b60.png

表名使用的是一个预输入控件,来试图猜测哪个表格与你的模型相关联,并且所有领域都有一个翻转工具,提示你如何填写出来。在用Gii生成它之前,你可以预览代码,并且所有代码模板是完全可以自定义的。

还有几个命令行工具可以帮你为你的自动化测试创建数据库迁移,信息翻译(I18N:国际化)和数据库fixtures 代码模板。例如,你可以使用如下命令创建一个新的数据库迁移文件:

yii migrate/create create_user_table

这将会在 {appdir}/migrations上创建一个新的迁移模板,看起来像这样的:

<?php     use yiidbSchema;     class m140924_153425_create_user_table extends yiidbMigration    {        public function up()        {         }         public function down()        {            echo "m140924_153425_create_user_table cannot be reverted.n";             return false;        }}

所以我们可以说,我想添加在该表中再添加几列。我只想添加以下内容到up 方法中:

public function up(){    $this->createTable('user', [        'id' => Schema::TYPE_PK,        'username' => Schema::TYPE_STRING . ' NOT NULL',        'password_hash' => Schema:: TYPE_STRING . ' NOT NULL'    ], null);}

然后,保证我可以反向迁移,下面我将添加down 方法:

public function down(){$this->dropTable('user');}

创建该表将会简单包括一个在运行在命令行的命令:

./yii migrate

然后移除该表:

./yii migrate/down

7、容易调整为最佳性能

大家都知道,一个网站很慢的话会很容易让用户产生不满,所以Yii提供了几种工具来帮助你从应用中“挤”出更多的速度。

所有Yii的缓存组件都是从yii/caching/Cache扩展来的,你可以选择任何一种,你想同时使用一个通用API扩展的缓存系统。你甚至可以注册多个高速缓存组件。Yii目前支持数据库和文件缓存,APC,Memcache, Redis, WinCache, XCache和Zend 数据缓存。

默认情况下,如果你正在使用Active Record,然后Yii会运行一个额外的查询,来确定表参与生成模型的架构。你可以通过编辑注配置文件设置应用程序,从而缓存这些架构:

return [    // ...    'components' => [        // ...        'db' => [            // ...            'enableSchemaCache' => true,            'schemaCacheDuration' => 3600,            'schemaCache' => 'cache',        ],        'cache' => [            'class' => 'yiicachingFileCache',        ],    ],];

最后,Yii有一个命令行工具,使前端资源极简化更容易。只需运行以下命令来生成配置模板:

./yii asset/template config.php

然后,编辑该配置来指定工具,达到你想要的简化效果(如关闭编译器, YUI Compressor,或UglifyJS)。生成的配置模板,如下所示:

 'java -jar compiler.jar --js {from} --js_output_file {to}',        'cssCompressor' => 'java -jar yuicompressor.jar --type css {from} -o {to}',        'bundles' => [            // 'yiiwebYiiAsset',            // 'yiiwebJqueryAsset',        ],        'targets' => [            'appconfigAllAsset' => [                'basePath' => 'path/to/web',                'baseUrl' => '',                'js' => 'js/all-{hash}.js',                'css' => 'css/all-{hash}.css',            ],        ],        'assetManager' => [            'basePath' => __DIR__,            'baseUrl' => '',        ],    ];

接着,运行此控制台命令来实现压缩:

'components' => [    // ...    'assetManager' => [        'bundles' => require '/app/assets_compressed.php'    ]]

注意:你必须要手动下载和安装这些外部工具。

结论:

像任何一个好的框架一样,Yii能够帮助你快速创建流行的web应用,并确保它们可以做的很好。通过做许多繁琐的事情,它帮你你创建安全的和可测试的网站。你可以轻松的使用它提供的大部分功能,或者你也可以修改其中任何一个来适应你的需求。真心建议你在你的下一个web项目中考虑一下它!

以上就是为什么我们要选择yii框架的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/351130.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年11月5日 22:21:48
下一篇 2025年11月5日 22:23:06

相关推荐

  • 探究最佳响应式布局框架:竞争激烈!

    响应式布局框架大比拼:谁是最佳选择? 随着移动设备的普及和多样化,网页的响应式布局变得越来越重要。为了满足用户的不同设备和屏幕尺寸,在设计和开发网页时采用响应式布局框架是必不可少的。然而,面对众多的框架选择,我们不禁要问:哪个是最佳选择? 以下将对目前比较流行的三种响应式布局框架进行比较评价,它们分…

    2025年12月24日
    000
  • 深入学习响应式布局框架:适合初学者到专家的详尽指南

    响应式布局框架解析:从初学者到专家的必备指南 随着移动设备的普及和多样化,响应式布局成为了现代Web设计的必备技能。响应式布局框架以其简单、灵活和可维护的特点,成为了开发者们的首选工具。然而,对于初学者来说,学习和理解响应式布局框架可能会感到有些困惑。本文将从初学者到专家,为您提供一个详细的指南,帮…

    2025年12月24日
    000
  • 选择最适合您的响应式布局框架:综合评估不同工具

    响应式设计是指网页可以根据不同设备的屏幕尺寸和分辨率进行自适应的布局,以确保在各种设备上都能提供良好的浏览体验。为了方便开发者实现响应式布局,出现了许多优秀的框架和工具。本文将汇总一些主流的响应式布局框架,并提供具体的代码示例,帮助读者选择最适合自己的工具。 Bootstrap(https://ge…

    2025年12月24日 好文分享
    000
  • 探索五种流行的响应式设计框架

    随着移动设备的广泛应用和互联网的普及,响应式布局已经成为了网页设计的重要概念。响应式布局能够根据用户使用的设备(如手机、平板、电脑等)不同的屏幕尺寸和分辨率,自动适应调整网页的布局和样式,提供更好的用户体验。 为了快速实现响应式布局,开发者可以使用现成的响应式布局框架。这些框架提供了一系列的CSS和…

    2025年12月24日
    000
  • 了解Ajax框架:探索常见的五种框架

    了解Ajax框架:探索常见的五种框架,需要具体代码示例 引言:在现代Web应用开发中,Ajax是必不可少的技术之一。它以其支持异步数据交互,提升用户体验等特点,成为了前端开发中不可或缺的一部分。为了更好地了解和掌握Ajax框架,本文将介绍五种常见的Ajax框架,并提供具体的代码示例,帮助读者深入了解…

    2025年12月24日
    000
  • 解析网页设计中CSS框架和排版的作用与优点

    在如今的网页设计领域,排版和CSS框架扮演着至关重要的角色。而在这种快节奏的工作中,更快速、更高效地完成任务显得尤为关键,这就是排版和CSS框架的优势所在。本文将会探讨如何使用这些工具来优化网页设计,同时提供一些实际的代码篇例,以便读者更好地理解。 一、CSS框架的作用和优势 CSS框架是为了能够更…

    2025年12月24日
    000
  • 揭开提高手机网页开发效率的秘密武器:了解手机CSS框架的全貌

    在如今移动互联网盛行的时代,手机网页开发已经成为一项必要的技能。相比于传统PC端网页,手机网页的开发要面临更多的挑战和限制。因此,使用一些高效的开发工具和技巧可以大大提高开发效率和质量。其中之一就是手机CSS框架。本文将介绍手机CSS框架的基本概念、常用的手机CSS框架以及具体代码示例,希望能对大家…

    2025年12月24日
    000
  • Yii框架中如何使用CSS样式?

    如何在Yii框架中引用CSS样式? Yii框架是一个高性能、灵活性强的PHP框架。在开发网站或Web应用程序时,样式表(CSS)是非常重要的一部分,它可以使网站的外观更加美观、统一。在Yii框架中,我们可以通过简单的步骤来引用CSS样式,并让网页中的元素应用这些样式。 步骤1:创建CSS样式文件首先…

    2025年12月24日
    000
  • 常见的css框架有哪些

    常见css框架:1、Bootstrap框架;2、Foundation框架,一个专业的前端框架;3、Pure框架,优点是渲染快;4、Skeleton框架;5、99lime HTML KickStart框架,适合网站快速开发;6、Kube框架。 本教程操作环境:windows7系统、CSS3版、Dell…

    2025年12月24日 好文分享
    000
  • 15 个优秀的响应式 Web 设计 HTML 和 CSS 框架

    【推荐教程:CSS视频教程 】 响应式 Web 设计旨在为各种设备(从台式机显示器到手机)提供最佳的浏览体验。本文汇总了一些优秀的响应式 Web 设计 HTML 和 CSS 框架。这些框架都是开源的并免费的。 对响应式 Web 框架进行比较并不那么容易。有的框架适合设计更快、更精简网站的某些功能,而…

    2025年12月24日 好文分享
    000
  • 最受欢迎的10大CSS框架

    web 开发工程师在开发页面样式的时候需要花费大量的时间开发,其中最头疼的还是浏览器的兼容性问题,最省事的是使用 css 框架,幸运的是一些大神编写了一套精美的 css 框架并开源出来,那么有哪些不错的 css 框架呢? 我收集了一些资料和数据来和大家讨论,下面我就说说 Github 上 star …

    好文分享 2025年12月24日
    000
  • html5如何隐藏图标_使用CSS隐藏HTML5页面图标【页面】

    可通过移除icon标签、设href为空或data URL、配置HTTP响应头禁用请求、或使用1×1透明PNG图标四种方法隐藏HTML5页面图标。 如果您在HTML5页面中希望隐藏默认显示的网页图标(favicon),则可能是由于浏览器自动加载了默认图标或页面中存在未正确配置的图标链接。以下是实现隐藏…

    2025年12月23日
    000
  • JavaScript中如何将Base64图片转换为ImageData数组

    本教程详细介绍了如何使用JavaScript将Base64编码的图片字符串转换为`ImageData`数组。通过利用HTML Canvas API,我们可以创建一个图像对象,将其绘制到画布上,然后通过`getImageData`方法提取出包含R、G、B、A像素数据的`Uint8ClampedArra…

    2025年12月23日
    000
  • HTML文件的框架是什么?如何编辑HTML文档?

    一个最基本的html文件框架包含以下核心部分:1.声明html5文档类型,避免浏览器怪异模式;2.作为根元素并指定语言;3. 包含元数据如设置字符编码、适配移动设备、定义网页标题;4.承载实际内容,如 标题和 段落;编辑html需用文本编辑器(如vs code)创建或打开.html文件,编写代码后保…

    2025年12月22日 好文分享
    000
  • 学习canvas框架 详解常用的canvas框架

    探索Canvas框架:了解常用的Canvas框架有哪些,需要具体代码示例 引言:Canvas是HTML5中提供的一个绘图API,通过它我们可以实现丰富的图形和动画效果。为了提高绘图的效率和便捷性,许多开发者开发了不同的Canvas框架。本文将介绍一些常用的Canvas框架,并提供具体代码示例,以帮助…

    2025年12月21日
    000
  • 学习不同canvas框架:了解各种canvas框架的特性与使用场景

    深入研究canvas框架:掌握多种canvas框架的特点与应用场景,需要具体代码示例 近年来,Web前端开发的重要领域之一是图像处理和动画效果。为了实现这些效果,开发人员通常使用HTML5的canvas元素。canvas元素提供了一个可以通过JavaScript来绘制图形的空白容器。 为了更好地利用…

    2025年12月21日
    000
  • 简介:HTML中的CSS框架是什么?

    什么是HTML中的CSS框架?一种简介 HTML和CSS是构建网页的两个基本技术。HTML用于创建网页结构,而CSS则用于设计网页的外观和样式。在开发网页时,我们经常需要为每个元素编写样式,这可能非常繁琐而耗时。幸运的是,CSS框架的出现解决了这个问题,它们提供了一套预定义的样式和布局,简化了网页开…

    2025年12月21日
    000
  • 掌握CSS框架,提升网页设计效果的利器

    HTML是构建网页结构的标记语言,而CSS则是用于美化和布局网页的样式表语言。在网页设计中,使用CSS框架可以提升设计效果,使网页呈现出更专业、更吸引人的外观。本文将介绍一些常见的CSS框架,并分析它们的特点和优势。 Bootstrap(响应式设计) Bootstrap是目前最受欢迎的CSS框架之一…

    2025年12月21日
    000
  • 深入研究CSS框架,提升网页布局和样式的能力

    CSS(Cascading Style Sheets)是一种用于描述网页样式和布局的语言,它使得网页设计更加灵活和易于管理。然而,编写和管理大型网页样式表可能会变得复杂和耗时。为了解决这个问题,开发人员们创建了各种CSS框架,这些框架提供了一套预定义的样式和布局模板,使得网页开发更加快速和高效。 本…

    2025年12月21日
    000
  • HTML框架怎么用

    一个浏览器文档窗口只能显示一个网页文件,但是可以通过使用框架,在同一个浏览器窗口中显示不止一个页面,本文就来介绍一下html框架 一、框架 一个浏览器文档窗口只能显示一个网页文件,但是可以通过使用框架,在同一个浏览器窗口中显示不止一个页面。使用框架的页面主要包含两个部分,一个是框架集,另一个就是具体…

    好文分享 2025年12月21日
    000

发表回复

登录后才能评论
关注微信