所以我正在使用Laravel 5.2和Entrust包来管理角色/权限
我正在构建一个函数,该函数应该将用户添加到'users'表,同时添加与'role_user'表的关系。我从multi_select传递一个数组,然后将其附加到用户。
它将用户完美地添加到“用户”表中,但不会在“role_user”表中添加关系。我希望得到一些帮助,找出问题所在。
相关表单中的部分:
{!! Form::select('roles[]', $roles, null, ['multiple' => 'multiple', 'class' => 'select-width-100 form-control roles']) !!}
我的StoreUser功能
public function StoreUser(Request $request)
{
$input = Request::all();
$user = New User;
$user->name = $input['username'];
$user->email = $input['email'];
$user->password = Hash::make($input['password']);
$roles = $input['roles'];
foreach ($roles as $role)
{
$role_id = Role::where('name', $role)->first();
$user->roles()->attach($role_id);
}
$user->save();
return redirect('/settings/users');
}
以下是我的User.php模型
<?php
namespace App;
use Zizaco\Entrust\Traits\EntrustUserTrait;
use Illuminate\Foundation\Auth\User as Authenticatable;
class User extends Authenticatable
{
use EntrustUserTrait;
/**
* The attributes that are mass assignable.
*
* @var array
*/
protected $fillable = [
'name', 'email', 'password',
];
/**
* The attributes that should be hidden for arrays.
*
* @var array
*/
protected $hidden = [
'password', 'remember_token',
];
}
答案 0 :(得分:0)
我管理修复它。 我应该寻找&#39; id&#39;而不是&#39; name&#39;,所以这个:
foreach ($roles as $role)
{
$role_id = Role::where('name', $role)->first();
$user->roles()->attach($role_id);
}
应该是这样的:
foreach ($roles as $role)
{
$role_id = Role::where('id', $role)->first();
$user->roles()->attach($role_id);
}