如何修复 laravel 5.2 zizaco 委托:迁移类名验证?

Posted

技术标签:

【中文标题】如何修复 laravel 5.2 zizaco 委托:迁移类名验证?【英文标题】:How to fix in laravel 5.2 zizaco entrust:migration class name validation? 【发布时间】:2016-04-04 10:24:35 【问题描述】:

我遵循了来自 GitHub Link 的 zizac/entrust 安装教程,但遇到了错误:

类名必须是有效的对象或字符串 var/www/html/laravel_test/vendor/zizaco/entrust/src/commands/MigrationCommand.php 在第 86 行

MigrationCommand.php 文件地址:Link

输出:

php artisan entrust:migration

Tables: roles, role_user, permissions, permission_role
A migration that creates 'roles', 'role_user', 'permissions', 'permission_role' tables will be created in database/migrations directory

Proceed with the migration creation? [Yes|no] (yes/no) [yes]: yes

Creating migration...
PHP Fatal error:  Class name must be a valid object or a string in /var/www/html/laravel_test/vendor/zizaco/entrust/src/commands/MigrationCommand.php on line 86

命令:php artisan vendor:publish 成功。

文件:config/entrust.php 存在。

我没有更改 config/auth.php 文件的任何选项,与 - auth.php 相同。如何解决?

【问题讨论】:

【参考方案1】:

接受的答案可能会解决问题,但编辑直接供应商文件是非常糟糕的做法。如果您决定更新 Entrust 并且他们修复了他们的代码库,以下内容将解决您可能遇到的问题,并将支持您的应用程序仍然工作。

将以下行添加到 config/auth.php 下面:

/*
|--------------------------------------------------------------------------
| User Providers
|--------------------------------------------------------------------------
|
| All authentication drivers have a user provider. This defines how the
| users are actually retrieved out of your database or other storage
| mechanisms used by this application to persist your user's data.
|
| If you have multiple user tables or models you may configure multiple
| sources which represent each model / table. These sources may then
| be assigned to any extra authentication guards you have defined.
|
| Supported: "database", "eloquent"
|
*/

Laravel 5.1 - 5.4

'model' => \App\Models\User::class,
'table' => 'users',

一旦 Entrust 推出更新,您可以删除或保留它。由你决定。

【讨论】:

【参考方案2】:

在第 86 行的 vendor/zizaco/entrust/src/commands/MigrationCommand.php 中。

Laravel 5.1.* 添加行

$usersTable  = Config::get('auth.table');
$userModel   = Config::get('auth.model');

Laravel 5.2.* 添加行

$usersTable  = Config::get('auth.providers.users.table');
$userModel   = Config::get('auth.providers.users.model');

【讨论】:

虽然这段代码可以回答这个问题,但最好包含一些上下文,解释它是如何工作的以及何时使用它。从长远来看,纯代码的答案没有用处。【参考方案3】:

在第 86 行的 vendor/zizaco/entrust/src/commands/MigrationCommand.php 中

删除线:

    $usersTable  = Config::get('auth.table');
    $userModel   = Config::get('auth.model');

添加行:

$usersTable  = Config::get('auth.providers.users.table');
$userModel   = Config::get('auth.providers.users.model');

和 config/auth.php 文件像我一样写提供者行:

'providers' => [
    'users' => [
        'driver' => 'eloquent',
        'model' => App\User::class,
        'table' => 'users',
    ],

    // 'users' => [
    //     'driver' => 'database',
    //     'table' => 'users',
    // ],
],

那么你的问题就会解决:快乐编码

【讨论】:

这样就解决了问题。我在 Laravel 5.2 上并使用多重身份验证。这就像魅力!谢谢 非常感谢您的回答。它在 laravel 5.2 上运行良好..这应该被标记为正确答案..:-) @taposghosh,它在 role->delete() 操作上给出了相同的错误。我还有什么地方需要改变? 您不应编辑直接供应商文件,因为它们将在未来的更新中被覆盖。相反,您应该在配置文件中添加正确的行,直到 Entrust 更新其代码库以使用更新的 Laravel auth 布局。 你救了我兄弟【参考方案4】:

尝试运行:

php artisan config:cache

确保您的应用程序使用新的配置文件

编辑

好的,现在我明白了,这个库要使用:

  $usersTable  = Config::get('auth.table');
  $userModel   = Config::get('auth.model');

但是auth 中已经没有这样的东西了。

因此,作为临时解决方法,您应该将tablemodel 添加到auth 文件中,如下所示:https://github.com/laravel/laravel/blob/5.1/config/auth.php

并等到 Entrust 升级后将其删除

【讨论】:

谢谢,还是同样的问题。我认为问题出在 config/auth.php 文件上。 您能出示您的User.php 文件吗?它应该在App 命名空间中

以上是关于如何修复 laravel 5.2 zizaco 委托:迁移类名验证?的主要内容,如果未能解决你的问题,请参考以下文章

laravel-如何在 5.1 中使用 zizaco 获得具有所有角色和所有权限的用户?

如何修复Laravel 5.2中的“Undefined variable:subtask”

laravel(4.2) +Zizaco

Zizaco Entrust Laravel对页面中的每个@权限进行mysql请求。

使用 Zizaco/entrust 包的 `name` 字段的自定义名称

Laravel 5.2 工匠“迁移”不起作用