ASP站长网前段时间第一次使用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字符串
 */

dawei

【声明】:九江站长网内容转载自互联网,其相关言论仅代表作者个人观点绝非权威,不代表本站立场。如您发现内容存在版权问题,请提交相关链接至邮箱:bqsm@foxmail.com,我们将及时予以处理。