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 app\controllers;

use yii\web\Controller;

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”

在操作方法中,yii\web\Controller::render() 被用来渲染一个名为 say 的视图文件。 message 参数也被传入视图,这样就可以在里面使用。操作方法会返回渲染结果。结果会被应用接收并显示给最终用户的浏览器(作为整页 HTML 的一部分)。

创建视图

视图是你用来生成响应内容的脚本。为了说 “Hello”,你需要创建一个 say 视图,以便显示从操作方法中传来的 message 参数。

<?php
use yii\helpers\Html;
?>
<?= Html::encode($message) ?>

 

say 视图应该存为 views/site/say.php 文件。当一个操作中调用了 yii\web\Controller::render() 方法时,它将会按 views/控制器 ID/视图名.php 路径加载 PHP 文件。

注意以上代码,message 参数在输出之前被 yii\helpers\Html::encode() 方法处理过。这很有必要,当参数来自于最终用户时,参数中可能隐含的恶意 JavaScript 代码会导致跨站脚本(XSS)攻击

当然了,你大概会在 say 视图里放入更多内容。内容可以由 HTML 标签,纯文本,甚至 PHP 语句组成。实际上 say 视图就是一个由 yii\web\Controller::render() 执行的 PHP 脚本。视图脚本输出的内容将会作为响应结果返回给应用。应用将依次输出结果给最终用户。

试运行

创建完操作和视图后,你就可以通过下面的 URL 访问新页面了:

http://hostname/index.php?r=site/say&message=Hello+World


Yii2.0实现注册登录

首先看SiteController.php

以下是必须引入的

use frontend\models\SiteLoginForm;
use frontend\models\User;
use frontend\models\SignupForm;

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 frontend\models;
use Yii;
use yii\web\IdentityInterface;

class User extends \yii\db\ActiveRecord implements \yii\web\IdentityInterface
{
    /**
     * @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' => 'frontend\models\User',
        'enableAutoLogin' => true,
    ],
],

 

SignupForm.php代码

//注意这里的规则由你自己定义有几个地段哈
public function rules()
{
     return [
        ['username', 'filter', 'filter' => 'trim'],
        ['username', 'required','message' => '用户名不能为空'],
        ['username', 'unique', 'targetClass' => '\frontend\models\User', '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;
}

 

posted on 2016-04-11 01:07  staroop  阅读(1382)  评论(0编辑  收藏  举报