拉拉维尔委托更改表名

  • 本文关键字: php laravel entrust
  • 更新时间 :
  • 英文 :


>我正在使用 laravel 5.2 多身份验证,所以我创建了一个新的管理表而不是用户表。

我已经为角色和权限安装了委托。在委托安装过程中,我将委托:迁移内容更改为:

public function up()
{
    // Create table for storing roles
    Schema::create('roles', function (Blueprint $table) {
        $table->increments('id');
        $table->string('name')->unique();
        $table->string('display_name')->nullable();
        $table->string('description')->nullable();
        $table->timestamps();
    });
    // Create table for associating roles to users (Many-to-Many)
    Schema::create('role_management', function (Blueprint $table) {
        $table->integer('management_id')->unsigned();
        $table->integer('role_id')->unsigned();
        $table->foreign('management_id')->references('id')->on('managements')
            ->onUpdate('cascade')->onDelete('cascade');
        $table->foreign('role_id')->references('id')->on('roles')
            ->onUpdate('cascade')->onDelete('cascade');
        $table->primary(['management_id', 'role_id']);
    });
    // Create table for storing permissions
    Schema::create('permissions', function (Blueprint $table) {
        $table->increments('id');
        $table->string('name')->unique();
        $table->string('display_name')->nullable();
        $table->string('description')->nullable();
        $table->timestamps();
    });
    // Create table for associating permissions to roles (Many-to-Many)
    Schema::create('permission_role', function (Blueprint $table) {
        $table->integer('permission_id')->unsigned();
        $table->integer('role_id')->unsigned();
        $table->foreign('permission_id')->references('id')->on('permissions')
            ->onUpdate('cascade')->onDelete('cascade');
        $table->foreign('role_id')->references('id')->on('roles')
            ->onUpdate('cascade')->onDelete('cascade');
        $table->primary(['permission_id', 'role_id']);
    });
}

entrust.php为:

return [
'role' => 'AppRole',
'roles_table' => 'roles',
'permission' => 'AppPermission',
'role_user_table' => 'role_management',
];

我有 3 个模型,角色和权限和管理。一切正常,但问题是当我想使用以下代码将角色附加到role_management表中时:

public function store(userManagementFormRequest $request)
{
    $user=new Management(array(
        'name'=>$request->get('name'),
        'password'=>bcrypt($request->get('password')),
    ));
    $user->save();
    $user->attachRoles($_POST['role']);
    return redirect()->back()->with('userStatus','عملیات با موفقیت انجام گردید.');
}

它将显示一个错误:

SQLSTATE[42S02]:找不到基表或视图:1146 表 'digikala.management_role' 不存在 (SQL: 插入management_rolecreated_atmanagement_idrole_idupdated_at ) 值 ( 2016-03-21 14:26:24, 1, 1, 2016-03-21 14:26:24))

我不知道为什么它显示management_role而不是role_management,而正确的表名是role_management。另外,我只有两列, management_idrole_id ,在这个表中,而且在此错误中,它想created_atupdated_at插入到这个表中。

我使用了作曲家配置:缓存和

作曲家缓存:清除和撰写转储自动加载,但什么也没发生。

我的代码有什么问题吗?管理模式:

namespace App;
use IlluminateFoundationAuthUser as Authenticatable;
use ZizacoEntrustTraitsEntrustUserTrait;
class Management extends Authenticatable
{
use EntrustUserTrait;
protected $table='managements';
protected $fillable=['name','password'];
public function roles()
{
    return $this->belongsToMany('AppRole')->withTimestamps();
}
}

无需覆盖roles关系函数。它已经存在于EntrustUserTrait中。

您可以删除它,它应该可以工作。

相关内容

  • 没有找到相关文章

最新更新