热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

Yii安装使用教程(转)

Yii是一个基于组件的高性能PHP框架,用于快速开发大型Web应用。它使Web开发中的可复用度最大化,可以显著提高你的Web应用开发速度。Yii这个名字(读作易(Yee)或[ji:])代表简单(easy),高效(efficient)和可扩展
Yii 是一个基于组件的高性能 PHP 框架,用于快速开发大型 Web 应用。它使Web开发中的 可复用度最大化,可以显著提高你的Web应用开发速度。Yii 这个名字(读作易(Yee) 或 [ji:])代表 简单(easy), 高效(efficient)可扩展(extensible).

中文帮助:http://www.yiiframework.com/doc/guide/1.1/zh_cn/quickstart.what-is-yii

一、下载yiiframework,当前最新版本是1.1.6

下载地址:http://yii.googlecode.com/files/yii-1.1.6.r2877.tar.gz

二、解压缩,配置环境

将压缩包放在appservwww目录下面,启动apachemysql,在地址栏中输入:http://localhost/yii6/requirements/index.php,查看配置环境,PDOGD库需要配置一下,打开php.ini,加入:

extension=php_pdo_mysql.dll

extension=php_mysql.dll

(当然,以上两个文件必须提前放在php的扩展文件夹中),yii框架基于php5

Yii安装使用教程(转) - ydmx_lei - 边走边看

最新的PCEL下载地址:

http://downloads.php.net/pierre/

三、创建第一个应用

打开cmd,切换到appservwww目录下,输入:

D:\AppServ\www>yii6\framework\yiic webapp test

Create a Web application under 'D:\AppServ\www\test'? [Yes|No] yes

D:\AppServ\www>yii6\framework\yiic webapp test

Create a Web application under 'D:\AppServ\www\test'? [Yes|No] yes

      mkdir D:/AppServ/www/test

      mkdir D:/AppServ/www/test/assets

      mkdir D:/AppServ/www/test/css

   generate css/bg.gif

   generate css/form.css

   generate css/ie.css

   ...

   generate themes/classic/views/.htaccess

      mkdir D:/AppServ/www/test/themes/classic/views/layouts

      mkdir D:/AppServ/www/test/themes/classic/views/site

      mkdir D:/AppServ/www/test/themes/classic/views/system

Your application has been created successfully under D:\AppServ\www\test.

这样第一个应用就建立好了。

yii6这个目录可以放在任意一个可读的目录中,不一定要放在appservwww下,在生产中,一般将此目录放在比较安全的地方,比如:d:\,创建应用的时候,就可以:D:\yii6\framework\yiic webapp webapp d:\appserv\www\test

(如果你使用Eclipse或者NetBeans开发工具,将YIIframework作为包含文件,这样开发起来提示就比较多了。^_^)

四、查看应用

地址栏中输入:http://localhost/test/

没写一行代码,就可以看到程序正常运行了。跟ROR差不多。

五、文件结构说明

Yii安装使用教程(转) - ydmx_lei - 边走边看

六、连接数据库

YII的数据库连接配置在主配置文件config/main.php中进行配置。

如果是sqllite数据库,只需要指定正确的数据库文件位置即可;

如果是mysql数据库,或者其他数据库(pgsql/oracle),需要注释掉原来的配置。

如下:(mysql

'db'=>array(

'connectionString' => 'sqlite:'.dirname(__FILE__).'/../data/testdrive.db',

),

// uncomment the following to use a MySQL database

/*

'db'=>array(

'connectionString' => 'mysql:host=localhost;dbname=testdrive',

'emulatePrepare' => true,

'username' => 'root',

'password' => '',

'charset' => 'utf8',

),

*/

将上面的代码修改为:

/*

'db'=>array(

'connectionString' => 'sqlite:'.dirname(__FILE__).'/../data/testdrive.db',

),

*/

// uncomment the following to use a MySQL database

'db'=>array(

'connectionString' => 'mysql:host=localhost;dbname=test', //test为数据库名

'emulatePrepare' => true,

'username' => 'root', //这里是数据库用户名

'password' => 'livedoor2008', //这里是你的数据库密码

'charset' => 'utf8',

),

七、创建表结构并配置CRUD(注意:YII使用的phpPDO来访问数据库的,所以在使用数据库时,务必配置好PDO

第一步:创建表结构

CREATE TABLE tbl_user

(

id INTEGER NOT NULL PRIMARY KEY AUTO_INCREMENT,

username VARCHAR(128) NOT NULL,

password VARCHAR(128) NOT NULL,

salt VARCHAR(128) NOT NULL,

email VARCHAR(128) NOT NULL,

profile TEXT

) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_unicode_ci;

等等,其他表结构查看yii6\demos\blog\protected\data下。

第二步:配置CRUD

YIICRUD可以自动生成,使用GII这个工具。

要使用GII,在主配置文件中,打开GII即可,并设置密码。

// autoloading model and component classes

'import'=>array(

'application.models.*',

'application.components.*',

),

'modules'=>array(

// uncomment the following to enable the Gii tool

'gii'=>array(

'class'=>'system.gii.GiiModule',

'password'=>'livedoor2008',

  // If removed, Gii defaults to localhost only. Edit carefully to taste.

'ipFilters'=>array('127.0.0.1','::1'),

),

),

保存文件后,在地址栏中输入:

http://localhost/test/index.php?r=gii

输入设置密码,便可以使用GII了。

八、根据表结构生成表的模型类

第一步,使用GII生成tbl_user的模型类:

Yii安装使用教程(转) - ydmx_lei - 边走边看

点击生成(Generate),模型类User.php就生成了,它位于protected/modules/下。

第二步,使用GII生成对tbl_userCRUD操作类,并加入测试数据:

Yii安装使用教程(转) - ydmx_lei - 边走边看

这里,GII帮我们生成了一个UserController.php控制器文件和user的多个视图文件。

UserController.php位于protected/controllers/下,多个视图文件位于views/user下。

九、针对表生成并实现CRUD操作

访问user控制器:http://localhost/test/index.php?r=user

如果要操作,需要用管理员admin/admin登录。

查看(Read/添加(Create/删除(Delete/更新(Update),随你了。

十、MVC基础

M -- 模型,代表了数据(表)和具体的业务逻辑;

V -- 用户看到的内容,文本,颜色,表单等

C -- 用来管理模型和视图的通信

这样做的好处就是分离的程序和页面及业务逻辑,对于局部的修改不会影响到其他的内容。

YII的工作流分析:

http://localhost/index.php?r=post/show&id=1

假设,一个用户请求了以上的地址,YII会做如下处理:

前端控制器index.php,会创建一个web实例,并执行此实例;

1) 应用组件request会接收此请求,并交给urlManager对请求的地址进行分割,r=post/show,表示请求的是一个叫post的控制器,并执行show动作

2) Show动作对应showAction的方法,以上创建的实例会对该方法执行关联的过滤操作(过滤器,测试基准),如果容许访问,继续执行;否则访问终止;

3) showAction会找到ID=1的模型数据,并渲染一个视图;

4) 视图读取数据,并显示post模型的属性,执行完一些小物件后,渲染内容插入布局文件,最后显示给用户。

十一、前端控制器(入口脚本)

前端控制器是唯一一个能够直接为用户访问的脚本,一个是为了安全起见,一个是为了生成一个应用实例。

// 在生产环境中请删除此行

defined('YII_DEBUG') or define('YII_DEBUG',true);

// 包含Yii引导文件

require_once('path/to/yii/framework/yii.php');

// 创建一个应用实例并执行

$cOnfigFile='path/to/config/file.php';

Yii::createWebApplication($configFile)->run();

十二、使用组件

1) 通常,YII的组件随取随用,配置好的组件,如果不在preload中,则只有通过Yii::app()->组件ID进行访问时候,才会被应用创建。

2) 但是,Yii的核心组件(16个),即使不被访问,也会被创建。

十三、使用表单

十四、关于正则表达式

$str = 'dddfew4t34233fdfew we中文2323duids,';

var_dump(preg_match('/^(([\w\s,])|([^\x{00}-\x{ff}]))+$/u'$str));

\w -- 匹配字符(字母和数字)

\s -- 匹配空格 制表符和换行符

[^\x{00}-\x{ff}]))+$/u --匹配双字节

preg_match -- 使用perl风格的正则表达式

十五、YIIMVC结构

(一)模型 -- M

YII的模型类均继承自CModel或者其子类;

模型中封装了数据库的表的数据或者用户提交的数据(通常是业务逻辑的数据),这些数据通常会被模型中定义的rules规则进行验证;

YII模型有2种,一种是CFormModel,一般由用户提交,并且绝大多数是临时的放在内存中,当然也可以通过AR存到数据库中;另外一种是Active Record 模型,AR是一种对数据库数据面向对象方式访问的抽象方式,它的每一个对象表示为数据表中的每一行,一个列的值就是这个对象的一个属性。

(二)视图 -- V

将模型中的数据,配合HTML标签渲染;

视图中一般只写一些简单的数据逻辑,如:循环或者条件。也可以写一些YII的小物件或者HTML助手;更多复杂的业务逻辑放在模型(对数据的操作)或者控制器(业务逻辑)中。

(三)控制器 -- C

根据用户的请求,协调模型和视图,并将结果发给用户端

控制器继承自CController或者其子类

十六、使用AR进行数据库操作

建立表的模型

通过使用GII,非常容易的建立表的模型,例如:表tbl_user

var cpro_id = "u6885494";

推荐阅读
  • 本文详细探讨了 Java 中 Daemon 线程的特点及其应用场景,并深入分析了 Random 类的源代码,帮助开发者更好地理解和使用这些核心组件。 ... [详细]
  • 深入理解FastDFS
    FastDFS是一款高效、简洁的分布式文件系统,广泛应用于互联网应用中,用于处理大量用户上传的文件,如图片、视频等。本文探讨了FastDFS的设计理念及其如何通过独特的架构设计提高性能和可靠性。 ... [详细]
  • CGroups: 资源管理和控制
    CGroups(Control Groups)是Linux内核提供的一个功能,旨在限制、记录和隔离进程组使用的物理资源,如CPU、内存和I/O等。它通过精细的资源管理,支持现代容器技术如Docker的资源限制需求。 ... [详细]
  • 软件项目管理实践——Jenkins持续集成与Maven、GitHub的应用
    本文详细介绍了如何利用Jenkins实现持续集成,以及Maven和GitHub在项目开发中的具体应用。包括环境搭建、工具安装、项目创建及代码管理等关键步骤。 ... [详细]
  • 本文详细介绍了如何通过Percona插件监控MySQL 5.7数据库,包括环境准备、插件安装、配置调整及数据测试等步骤,旨在为用户提供一个高效且稳定的监控解决方案。 ... [详细]
  • Django框架的使用教程mysql数据库[三]
    Django的数据库1.在Django_test下的view.py里面model定义模型fromdjango.dbimportmodels#Createyourmodelshere ... [详细]
  • SQL注入实验:SqliLabs第38至45关解析
    本文深入探讨了SqliLabs项目中的第38至45关,重点讲解了堆叠注入(Stacked Queries)的应用技巧及防御策略。通过实际案例分析,帮助读者理解如何利用和防范此类SQL注入攻击。 ... [详细]
  • Linux 文件系统结构详解
    本文详细介绍了Linux操作系统的文件系统结构,包括其独特的树状目录体系、根目录的作用、目录与磁盘分区的关系等,并对各主要目录的功能进行了深入解析。 ... [详细]
  • 致信息安全爱好者的成长指南
    本文旨在为信息安全爱好者提供一份详尽的成长指南,涵盖从学习心态调整到具体技能提升的各个方面。 ... [详细]
  • 本文详细探讨了在Windows Server 2003环境下遇到MySQL连接失败(错误代码10061)的解决方案,包括通过卸载特定的Windows更新和调整系统注册表设置的方法。 ... [详细]
  • 使用Adobe Illustrator打造独特的家族徽章:牡鹿图腾设计教程
    本文详细介绍了一种基于《权力的游戏》灵感,运用Adobe Illustrator创作独特家族图腾——牡鹿徽章的方法。本教程不仅展示了具体的步骤,还提供了多种技巧,帮助读者创作出既具个人特色又符合设计原则的作品。 ... [详细]
  • 本文针对公司项目中普遍存在的IE浏览器兼容性问题,特别是IE9及以下版本,提出了具体的解决方案,确保用户在这些旧版浏览器中也能顺利实现图片上传预览功能。 ... [详细]
  • 在现代多线程编程中,Lock接口提供的灵活性和控制力超越了传统的synchronized关键字。Lock接口不仅使锁成为一个独立的对象,还提供了更细粒度的锁定机制,例如读写锁(ReadWriteLock)。本文将探讨如何利用ReentrantReadWriteLock提高并发性能。 ... [详细]
  • 本文详细介绍了MySQL在Linux环境下的主从复制技术,包括单向复制、双向复制、级联复制及异步复制等多种模式。主从复制架构中,一个主服务器(Master)可与一个或多个从服务器(Slave)建立连接,实现数据的实时同步。 ... [详细]
  • 本文详细探讨了在不同服务器上运行的PHP程序如何成功连接MySQL数据库的方法,包括常见的连接失败原因及解决方案。 ... [详细]
author-avatar
帝姬
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有