Yii2 的安装及简单使用

前段时间第一次使用Yii2框架,碰到了一些问题,这里记录一下。

Yii2安装:通过composer安装

1、首先要安装composer,我在另外一篇博客中介绍了如何在Windows下安装composer。

2、全局设置 Composer 使用中国镜像:

composer config -g repo.packagist composer https://packagist.phpcomposer.com

3、安装composer-asset-plugin(如果不安装composer-asset-plugin后面安装yii2时会出现问题,这里默认安装最新版)

composer global require "fxp/composer-asset-plugin"

4、(1)安装基础版,projectName是自己的项目名。

composer create-project --prefer-dist yiisoft/yii2-app-basic projectName

(2)安装高级版。(高级版区分了前后台目录backend,frontend)

composer create-project --prefer-dist yiisoft/yii2-app-advanced projectName

注:高级版安装后需要初始化,双击根目录下的"init.bat"文件,选择"0"(表示开发环境),之后选择"yes"就可以了,会自动生成入口文件。

5、配置域名信息就可以访问了。(高级版需要分别配置前后台域名)

可能出现的问题:

安装下来后可能会出现的问题:找不到vendor文件夹。

原因:composer-asset-plugin没有安装或者版本太低

解决办法:找到文件的根目录,即composer.json文件目录,打开命令行执行:composer update

Yii 2的简单使用:

1、路由优化

找到 /frontend/config/main.php 文件,找到以下代码,去掉注释,运行后发现可以去掉"?r="使用"/"代替,但是还是不能去掉index.php。

'urlManager' => [
    'enablePrettyUrl' => true,  // 美化url去掉 ?r=
    'showScriptName' => false,  // 隐藏index.php
    'rules' => [
    ],
],

要去掉index.php,还需要在入口文件下添加.htaccess文件,文件内容如下:

# use mod_rewrite for pretty URL support
RewriteEngine on
# if a directory or a file exists, use the request directly
RewriteCond %{REQUEST_FILENAME} !-f
RewriteCond %{REQUEST_FILENAME} !-d
# otherwise forward the request to index.php
RewriteRule . index.php

注:这个需要前后端都配置一遍。

2、驼峰命名路径访问

在yii2中如果使用驼峰命名,则默认使用"-",如要访问UserAdminController控制器下的actionTestUser方法,则访问路径为:/user-admin/test-user

3、使用post方法访问

在Yii2中如果不做处理,使用post访问会报错。这是因为Yii2使用post请求时默认会使用CSRF验证。

这里可以在表单中加入验证或者后台可以取消掉CSRF验证。

方法一:在表单中加入验证:(如果能使用这种方法最好)

<input name="_csrf" type="hidden" id="_csrf" value="<?= Yii::$app->request->csrfToken ?>" />

方法二:全局配置,在配置文件中加入 'enableCsrfValidation' => false

在config文件夹下找到"components"配置下的"request"配置,在里面加入'enableCsrfValidation' => false表示取消掉CSRF验证。

方法三:局部配置,在单个控制器下配置

可以在单个控制器下添加代码:

public $enableCsrfValidation = false;

这样在这个控制器下的方法就可以使用post请求了。

Yii2处理密码加密及验证

在Yii2中提供了密码加密以及验证的一系列方法,方便我们的使用,它使用的是bcrypt算法。查看源码我们可以发现它使用的是PHP函数password_hash()和crypt()生成。

加密:

/**
 * $password  要加密的密码
 * $hash    加密后的hash字符串
 */
$hash = Yii::$app->getSecurity()->generatePasswordHash($password);

验证密码:

/**
 * $password  要验证的明文密码
 * $hash    加密后的hash字符串
 */
Yii::$app->getSecurity()->validatePassword($password, $hash);

yii

相关推荐