您好我正在使用Laravel,并且我使用了几个用于身份验证的用户身份和Zizaco Confide和Zizaco Entrust的角色。我已经完成了设置过程,我有角色和权限。这创建了以下表格:
用户,角色,assigned_roles,权限,permission_role
表格结构如下:两位用户:
users table
id | username | email
1 | adminuser | admin@test.com
2 | subscriber | subscriber@test.com
roles
id | name
1 | admin
2 | subscriber
assigned_roles
id | user_id | role_id
1 | 1 | 1
2 | 1 | 2
3 | 2 | 2
permissions
id | name | display_name
1 | can_view_admin | Can View Admin Display
2 | can_view_articles | Can View Articles
permission_role
id | permission_id | role_id
1 | 1 | 1
2 | 1 | 2
3 | 2 | 2
我正在使用支持的标准控制器添加用户但是我已经向控制器添加了几行并注册表单(我使用的自定义视图,发布配置文件并在那里编辑)如下: / p>
public function create()
{
$roles = DB::table('roles')->orderBy('name', 'asc')->lists('name', 'id');
return View::make(Config::get('confide::signup_form'),['roles' => $roles ]);
}
这将返回数据库中的roles
,以便我可以将它们传递给多选,因为用户可以拥有多个角色。在我看来,我做了以下几点:
<form method="POST" action="{{{ URL::to('users') }}}" accept-charset="UTF-8">
<input type="hidden" name="_token" value="{{{ Session::getToken() }}}">
<input class="form-control" placeholder="{{{ Lang::get('confide::confide.username') }}}" type="text" name="username" id="username" value="{{{ Input::old('username') }}}">
@if(count($roles)>0)
{{ Form::label('select_client', 'Select Role', array('class' => 'label')); }}
{{ Form::select('role', $roles , Input::old('role'), array('class' => 'select', 'multiple')) }}
@endif
现在这个表格将转到我们不介意的confide包提供的标准控制器,但这是功能:
public function store()
{
$repo = App::make('UserRepository');
$user = $repo->signup(Input::all());
if ($user->id) {
if (Config::get('confide::signup_email')) {
Mail::queueOn(
Config::get('confide::email_queue'),
Config::get('confide::email_account_confirmation'),
compact('user'),
function ($message) use ($user) {
$message
->to($user->email, $user->username)
->subject(Lang::get('confide::confide.email.account_confirmation.subject'));
}
);
}
return Redirect::action('UsersController@login')
->with('notice', Lang::get('confide::confide.alerts.account_created'));
} else {
$error = $user->errors()->all(':message');
return Redirect::action('UsersController@create')
->withInput(Input::except('password'))
->with('error', $error);
}
}
如果成功注册了一个刚刚创建的用户ID,并且如果选择了多个角色,则如何更新assigned_roles表?我需要一个foreach循环吗?任何帮助将不胜感激!
答案 0 :(得分:1)
进入UserRepository
课程并将此代码添加到signup()
方法:
$this->save($user);
$role = array_get($input, 'role');
$user->roles()->attach($role);
现在仍然存在问题,因为使用$this->save()
时$user
在插入后没有获得id。您可以做的是直接使用$user->save()
:
$user->save();
$roles = array_get($input, 'role');
$user->attachRoles($roles);
或修改存储库中的save
方法,以便通过引用传递$user
:(添加&
)
public function save(User &$instance){
return $instance->save()
}