Yii2 - (七)规则的讲解

需求:普通管理员只可以查看修改自己的信息,而站长可以修改所有人的信息

一、用 gii 生成 user 模型和 CRUD 操作
01.png

02.png

二、创建“管理用户”和”规则“菜单
1、点击“路由”,然后点击
03.png
,即可以看到多了刚刚生成的 userController 的路由
04.png

将 /user/* 和 /user/index 移动至右边
05.png

将 /admin/rule/* 和 /admin/rule/index 也移动至右边,待会创建 “规则” 菜单

2、点击“菜单”创建以下菜单
06.png

07.png

三、添加“规则”(路由)给“权限控制”(权限)

1、点击“权限”然后进行创建“管理用户”的权限
08.png

2、点击“权限”,然后再点击”权限控制“的查看按钮,将 /admin/rule/* 移至右边
09.png

3、点击“角色”,为“站长”和“普通管理员”添加“管理用户”的权限
10.png

11.png

四、为“普通管理员”添加“修改用户”的规则

1、新建“修改用户”的规则

① 新建 backend\components\UserRule 这个类文件
12.png

② 刷新页面,左侧菜单出现“规则”的菜单,点击“规则”创建“修改用户”的规则
13.png

2、为“普通管理员”添加“修改用户”的规则

点击“角色”,再点击“普通管理员”的更新按钮
14.png

打开 auth_item 表,可以发现“普通管理员”这个记录被修改了
15.png

五、测试“修改用户”的规则是否发挥作用

1、登录 master 站长,点击“管理用户”,再点击 admin 修改的按钮,发现可以修改

2、登录 admin 普通管理员,点击“管理用户”,再点击 master 修改的按钮,发现无法可以修改
16.png

表明“修改用户”的规则对“普通管理员”这个角色发挥作用了。

注意:测试时务必把 \backend\main.php 的 * 注释掉
17.png

 

0 个评论

要回复文章请先登录注册