Yii 是什么
Yii 是一个高性能,基于组件的 PHP 框架,用于快速开发现代 Web 应用程序。名字 Yii (读作 易
)在中文里有“极致简单与不断演变”两重含义,也可看作 Yes It Is! 的缩写。
Yii 最适合做什么?
Yii 是一个通用的 Web 编程框架,即可以用于开发各种用 PHP 构建的 Web 应用。因为基于组件的框架结构和设计精巧的缓存支持,它特别适合开发大型应用,如门户网站、社区、内容管理系统(CMS)、电子商务项目和 RESTful Web 服务等。
系统要求
Yii 2.0 需要 PHP 5.4.0 或以上版本支持。
学习Yii框架首先要知道它的应用结构
composer.json Composer 配置文件, 描述包信息
config/ 包含应用配置及其它配置
console.php 控制台应用配置信息
web.php Web 应用配置信息
commands/ 包含控制台命令类
controllers/ 包含控制器类
models/ 包含模型类
runtime/ 包含 Yii 在运行时生成的文件,例如日志和缓存文件
vendor/ 包含已经安装的 Composer 包,包括 Yii 框架自身 views/ 包含视图文件
web/ Web 应用根目录,包含 Web 入口文件
assets/ 包含 Yii 发布的资源文件(javascript 和 css)
index.php 应用入口文件
yii Yii 控制台命令执行脚本
简单的实现helloworld
Yii 也是基于 MVC(Model-View-Controller)设计模式并基于该模式组织代码。
应用操作
为了 “Hello”,需要创建一个 say
操作,从请求中接收 message
参数并显示给最终用户。如果请求没有提供 message
参数,操作将显示默认参数 “Hello”。
操作必须声明在控制器中。为了简单起见,你可以直接在 SiteController
控制器里声明 say
操作。这个控制器是由文件controllers/SiteController.php
定义的。以下是一个操作的声明:
<?php namespace appcontrollers; use yiiwebController; class SiteController extends Controller { public function actionSay($message = 'Hello') { return $this->render('say', ['message' => $message]); } }
在上述 SiteController
代码中,say
操作被定义为 actionSay
方法。Yii 使用 action
前缀区分普通方法和操作。action
前缀后面的名称被映射为操作的 ID。
涉及到给操作命名时,你应该理解 Yii 如何处理操作 ID。操作 ID 总是被以小写处理,如果一个操作 ID 由多个单词组成,单词之间将由连字符连接(如 create-comment
)。操作 ID 映射为方法名时移除了连字符,将每个单词首字母大写,并加上 action
前缀。 例子:操作 IDcreate-comment
相当于方法名 actionCreateComment
。
上述代码中的操作方法接受一个参数 $message
,它的默认值是 “Hello”
(就像你设置 PHP 中其它函数或方法的默认值一样)。当应用接收到请求并确定由 say
操作来响应请求时,应用将从请求的参数中寻找对应值传入进来。换句话说,如果请求包含一个 message
参数,它的值是 “Goodybye”
, 操作方法中的 $message
变量也将被填充为 “Goodbye”
。
在操作方法中,yiiwebController::render() 被用来渲染一个名为 say
的视图文件。 message
参数也被传入视图,这样就可以在里面使用。操作方法会返回渲染结果。结果会被应用接收并显示给最终用户的浏览器(作为整页 HTML 的一部分)。
创建视图
视图是你用来生成响应内容的脚本。为了说 “Hello”,你需要创建一个 say
视图,以便显示从操作方法中传来的 message
参数。
<?php use yiihelpersHtml; ?> <?= Html::encode($message) ?>
say
视图应该存为 views/site/say.php
文件。当一个操作中调用了 yiiwebController::render() 方法时,它将会按 views/控制器 ID/视图名.php
路径加载 PHP 文件。
注意以上代码,message
参数在输出之前被 yiihelpersHtml::encode() 方法处理过。这很有必要,当参数来自于最终用户时,参数中可能隐含的恶意 JavaScript 代码会导致跨站脚本(XSS)攻击。
当然了,你大概会在 say
视图里放入更多内容。内容可以由 HTML 标签,纯文本,甚至 PHP 语句组成。实际上 say
视图就是一个由 yiiwebController::render() 执行的 PHP 脚本。视图脚本输出的内容将会作为响应结果返回给应用。应用将依次输出结果给最终用户。
试运行
创建完操作和视图后,你就可以通过下面的 URL 访问新页面了:
http://hostname/index.php?r=site/say&message=Hello+World
Yii2.0实现注册登录
首先看SiteController.php
以下是必须引入的
use frontendmodelsSiteLoginForm; use frontendmodelsUser; use frontendmodelsSignupForm; public function actionSignup() { $model = new SignupForm(); if ($model->load(Yii::$app->request->post())) { if ($user = $model->signup()) { // $login = new SiteLoginForm(); if(Yii::$app->getUser()->login($user)) { return $this->goHome(); } else { var_dump($user); } } } return $this->render('signup', [ 'model' => $model, ]); } public function actionLogin() { if (!Yii::$app->user->isGuest) { return $this->goHome(); } $model = new SiteLoginForm(); if ($model->load(Yii::$app->request->post()) && $model->login()) { return $this->goBack(); } else { return $this->render('login', [ 'model' => $model, ]); } }
frontend/models/User.php文件
namespace frontendmodels; use Yii; use yiiwebIdentityInterface; class User extends yiidbActiveRecord implements yiiwebIdentityInterface { /** * @inheritdoc */ public static function tableName() { return 'shop_user'; } /** * @inheritdoc */ public function rules() { return [ [['username', 'pwd', 'create_time'], 'required'], [['create_time'], 'integer'], [['username'], 'string', 'max' => 20], [['pwd'], 'string', 'max' => 32] ]; } /** * @inheritdoc */ public function attributeLabels() { return [ 'id' => 'ID', 'username' => 'Username', 'pwd' => 'Pwd', 'create_time' => 'Create Time', ]; } /** * Generates password hash from password and sets it to the model * * @param string $password */ public function setPassword($password) { $this->pwd = md5($password); } /** * @inheritdoc */ public static function findIdentity($id) { return static::findOne($id); //return isset(self::$users[$id]) ? new static(self::$users[$id]) : null; } /** * @inheritdoc */ public static function findIdentityByAccessToken($token, $type = null) { return static::findOne(['access_token' => $token]); /*foreach (self::$users as $user) { if ($user['accessToken'] === $token) { return new static($user); } } return null;*/ } /** * Finds user by username * * @param string $username * @return static|null */ public static function findByUsername($username) { $user = User::find() ->where(['username' => $username]) ->asArray() ->one(); if($user){ return new static($user); } return null; /*foreach (self::$users as $user) { if (strcasecmp($user['username'], $username) === 0) { return new static($user); } } return null;*/ } /** * @inheritdoc */ public function getId() { return $this->id; } /** * @inheritdoc */ public function getAuthKey() { return $this->authKey; } /** * @inheritdoc */ public function validateAuthKey($authKey) { return $this->authKey === $authKey; } /** * Validates password * * @param string $password password to validate * @return boolean if password provided is valid for current user */ public function validatePassword($password) { return $this->pwd === md5($password); } }
config/main.php代码
'components' => [ 'user' => [ 'identityClass' => 'frontendmodelsUser', 'enableAutoLogin' => true, ], ],
SignupForm.php代码
//注意这里的规则由你自己定义有几个地段哈 public function rules() { return [ ['username', 'filter', 'filter' => 'trim'], ['username', 'required','message' => '用户名不能为空'], ['username', 'unique', 'targetClass' => 'frontendmodelsUser', 'message' => '用户名已存在'], ['username', 'string', 'min' => 2, 'max' => 255], ['password', 'required','message' => '密码不能为空'], ['password', 'string', 'min' => 6], ]; } //注意这个方法里user表的字段 public function signup() { if ($this->validate()) { $user = new User(); $user->username = $this->username; $user->setPassword($this->password); $user->create_time = time(); if ($user->save()) { return $user; } } return null; }