我已经通过实施 SQL 代码来设置表和 rbac/init 脚本来填写角色/权限来设置数据库等。
我在创建用户时有一个 allocate() ,但我在 getRole() 上不断收到此错误:
yii\base\ErrorException 在 null 上调用成员函数 getRole()
public function addUser()
{
if($this->validate()) {
$user = new User();
$auth_key = Yii::$app->getSecurity()->generateRandomString(32);
$this->password = Yii::$app->getSecurity()->generatePasswordHash($this->password);
$user->email = $this->email;
$user->password = $this->password;
$user->active = $this->active;
$user->firstname = $this->firstname;
$user->lastname = $this->lastname;
// $user->nickname = $this->nickname;
$user->datecreated = time();
$user->auth_key = $auth_key;
$user->save(false);
$auth = Yii::$app->authManager;
$authorRole = $auth->getRole($this->role);
$auth->assign($authorRole, $user->getId());
return $user;
}else{
return false;
}
}
Run Code Online (Sandbox Code Playgroud)
$role 变量与其他用户属性一起通过 $_POST 传递。
请帮忙。谢谢。
你在这件事上走错了路。
这里的问题似乎是Yii::$app->authManager在应该设置的时候没有设置。这可能意味着您的 main.php 配置文件不包含正确的信息。它应包含以下组件:
return [
// ...
'components' => [
'authManager' => [
'class' => 'yii\rbac\DbManager',
],
// ...
],
];
Run Code Online (Sandbox Code Playgroud)
(http://www.yiiframework.com/doc-2.0/guide-security-authorization.html#configuring-rbac-manager)
在上面链接的示例中,使用了PhpManager,但在您的情况下,您将需要使用yii\rbac\DbManager
这样做意味着您将只有一个已加载的管理器,并且还将解锁所有操作过滤选项。