我正在使用Zizaco/entrust的依赖项在我的web 应用程序中创建角色及其权限,该应用程序是在 laravel 5.3 中构建的。每当我尝试保存新创建的权限时,我遇到的问题是(如标题所示)。它存储在roles
表中。
迁移文件未从原始 zizaco/entrust 包更改。我用php artisan vendor:publish
来创建迁移。Role 和 Permission 的模型很像文档中所说的:
namespace App\Models;
use Zizaco\Entrust\EntrustRole;
class Role extends EntrustRole
{
protected $table = 'roles';
/**
* The attributes that are mass assignable.
*
* @var array
*/
protected $fillable = [
'name', 'display_name', 'description',
];
}
和许可
namespace App\Models;
use Zizaco\Entrust\EntrustRole;
class Permission extends EntrustRole
{
protected $table = 'permissions';
/**
* The attributes that are mass assignable.
*
* @var array
*/
protected $fillable = [
'name', 'display_name', 'description',
];
}
在播种机文件中,我使用以下代码生成角色和播种机:
use App\Models\Permission;
use App\Models\Role;
use Illuminate\Database\Seeder;
class RoleSeeder extends Seeder
{
/**
* Run the database seeds.
*
* @return void
*/
public function run()
{
$owner = new Role();
$owner->name = 'owner';
$owner->display_name = 'Eigenaar';
$owner->save();
$createOwner = new Permission();
$createOwner->name = 'create-owner';
$createOwner->display_name = 'Eigenaar toevoegen';
$createOwner->save();
}
委托的配置文件也被修改为角色和权限模型的正确路径以及表格。
我试过 composer dump-autoload 甚至 php artisan cache:clear。
有什么我错过的吗?请帮忙。如果语法不正确,请原谅我的英语。
编辑:当我尝试通过以下行将我的权限附加到角色时:
$owner->attachPermission($createOwner);
我收到一个 sql 错误:
SQLSTATE[23000]:完整性约束违规:1452 无法添加或更新子行:外键约束失败(
reunions_dev
.permission_role
, CONSTRAINTpermission_role_permission_id_foreign
FOREIGN KEY (permission_id
) REFERENCESpermissions
(id
) ON DELETE CASCADE ON UPDATE CASCADE)
那是因为没有将 ID 链接到的权限记录。有点明显。