yii2搭建筑到后台并促成rbac权限控制案例教程

作者:白狼
出处:www.manks.top/article/yii2_frame_rbac_template 

本文版权归作者,欢迎转载,但未经作者同意要保留这个段子声明,且在篇章页面明显位置为有原文连接,否则保留追究法律责任的权。

1、安装yii2

无安装的伸手参见yii2史上顶简单式安装教程,没有有

早已安装之请继续羁押下一样步操作

2、配置数据库

2.1 配置数据库

改common/config/main-local.php
实际项目被本地的数据库往往跟线上数据库不等同,

咱俩这里配置到main-local.php就可以了,产品上线后,我们得以使用git或者svn忽略掉main-local.php,线上一直配置。

俺们这边运用的mysql数据库,配置如下

图片 1

自然啦,上面红圈圈的音要你协调手动修改掉,要是死偶合跟我之同一那便无须在修改了

2.2 创建user数据表,我们后要兑现后台登陆

说明:user表和menu表的始建好参见我们后面下载的组件yii2-admin里面的sql,具体目录在

vendor\mdmsoft\yii2-admin\migrations\schema-mysql.sql

 

CREATE TABLE `user` (
`id` int(11) NOT NULL AUTO_INCREMENT COMMENT '自增ID',  
`username` varchar(255) NOT NULL COMMENT '用户名',  
`auth_key` varchar(32) NOT NULL COMMENT '自动登录key',  
`password_hash` varchar(255) NOT NULL COMMENT '加密密码',  
`password_reset_token` varchar(255) DEFAULT NULL COMMENT '重置密码token',  
`email` varchar(255) NOT NULL COMMENT '邮箱',  
`role` smallint(6) NOT NULL DEFAULT '10' COMMENT '角色等级',  
`status` smallint(6) NOT NULL DEFAULT '10' COMMENT '状态',  
`created_at` int(11) NOT NULL COMMENT '创建时间',  
`updated_at` int(11) NOT NULL COMMENT '更新时间',  
PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=0 DEFAULT CHARSET=utf8 COMMENT='用户表';

2.3 访问frontend站点,先挂号个用户图片 2

登记成功后,右上角会显示登陆的状态,我们后会就此到这注册之用户

图片 3

连通下去我们设起布置后台的沙盘了。

3、利用AdminLTE渲染后台模板

后台的模板我们采用用 AdminLTE(Backend
theme for Yii2 Framework)

插播一弯:AdminLTE是一个通通响应管理模板。基于Bootstrap3框架,易定制模板。适合多屏幕分辨率,从小型移动装备到大型台式机。

嵌入了大多单页面,包括仪表盘、邮箱、日历、锁屏、登录以及注册、404不当、500不当等页面。

3.1 安装AdminLTE 

https://github.com/dmstr/yii2-adminlte-asset

打开上面的链接,按照操作步骤进行安装

这边我简述下团结之装步骤,cd advanced后,

 

因为是mac,这里直接composer进行安装就行了
composer require dmstr/yii2-adminlte-asset "2.*"

装成功后,vendor目录下会多几单文本夹,如下

图片 4

3.2 yii2安排整合AdminLTE,搭建筑帅气上档次的后台

下面我们配备下backend/config/main.php先预览下力量,小心脏捉急的渴望尽快尝尝胜果

 

'components' => [  
    'view' => [
        'theme' => [
            'pathMap' => [                
                '@app/views' => '@vendor/dmstr/yii2-adminlte-asset/example-views/yiisoft/yii2-app'             
             ],
        ],
    ],
],

图片 5

nice,页面瞬间好看多矣。

题目来了,我们是当components里面独自安排的theme,这样以后如改布局文件什么的凡颇无方便滴,下面我们将未铺文件拷贝下来挂掉yii自带的layout.

拿vendor/dmstr/yii2-adminlte-asset/example-views/yiisoft/yii2-app目录下的layouts和site拷贝 

盖掉backend/views/目录下之lauouts和site对应的文本

蒙后记忆屏蔽掉 components下面view的部署起

至这,后台模板的搭建告一段落,si不si很happy

 

4、下面我们用yii的rbac实现后台的权位决定

4.1 我们事先安排下简短路由 

backend/config/main.php文件之compontents加上下面的部署

 

'urlManager' => [    
    //用于表明urlManager是否启用URL美化功能,在Yii1.1中称为path格式URL,    
    // Yii2.0中改称美化。   
    // 默认不启用。但实际使用中,特别是产品环境,一般都会启用。   
    'enablePrettyUrl' => true,    
    // 是否启用严格解析,如启用严格解析,要求当前请求应至少匹配1个路由规则,    
    // 否则认为是无效路由。    
    // 这个选项仅在 enablePrettyUrl 启用后才有效。    
    'enableStrictParsing' => false,    
    // 是否在URL中显示入口脚本。是对美化功能的进一步补充。    
    'showScriptName' => false,    
    // 指定续接在URL后面的一个后缀,如 .html 之类的。仅在 enablePrettyUrl 启用时有效。    
    'suffix' => '',    
    'rules' => [        
        "<controller:\w+>/<id:\d+>"=>"<controller>/view",  
        "<controller:\w+>/<action:\w+>"=>"<controller>/<action>"    
    ],
],

接下当列的一干二净目录
backend/web下面创建.htaccess文件并累加如下内容,这个文件你还创造不下去,看来是真的用再行磨练磨练哦

Options +FollowSymLinks
IndexIgnore  */*

RewriteEngine on

# if a directory or a file exists, use it directly
RewriteCond  %{REQUEST_FILENAME} !-f
RewriteCond %{REQUEST_FILENAME} !-d

# otherwise forward it to index.php
RewriteRule . index.php

当然,你的apache必须要开启rewrite模块。

下面我们走访下gii模块测试下

http://localhost/advanced/backend/web/gii

校验是可的。

4.2 创建权限控制所要之数据表

累阅读

相关文章