yii2 rbac 每次走一个方法都要自己验证一次有没有权限吗?如果是配置的话怎么配置?
程序员文章站
2022-04-22 15:37:22
...
yii2 rbac 每次走一个方法都要自己验证一次用户有没有该控制器与Action的权限吗?如果是配置的话怎么配置?
回复内容:
yii2 rbac 每次走一个方法都要自己验证一次用户有没有该控制器与Action的权限吗?如果是配置的话怎么配置?
yii\filters\AccessRule::matchCalllback. 注意传递的参数 $rule, $action
[
'actions' => ['special-callback'],
'allow' => true,
'matchCallback' => function ($rule, $action) {
# write arbitrary access check logic
# permission = (rule [xxoo] action)
# return user->can(permission);
}
]
或者使用下面的方式, 见 yii2-admin
return [
'components' => [
'authManager' => [
'class' => 'yii\rbac\PhpManager', // or use 'yii\rbac\DbManager'
]
],
'as access' => [
'class' => 'mdm\admin\components\AccessControl',
],
];
AccessControl 支持配置 role
例如:
[
'actions' => ['edit'],
'allow' => true,
'roles' => ['@', 'author'],
],