php - Laravel Ardent 多对多关系抛出错误

标签 php mysql laravel laravel-5.1 ardent

我有一个 Ardent v3.3.0 模型如下:

class Company extends Ardent
{
    protected $fillable = [
        'name',
        'address'
    ];

    public static $rules = [
        'name'    => 'required',
        'address' => 'string'
    ];

    public function workers()
    {
        return $this->belongsToMany('App\Worker')->withPivot('worker_type');
    }
}

另一个模型是这样的:

class Worker extends Ardent
{

    protected $fillable = [
        'name',
    ];

    public static $rules = [
        'name'    => 'required',
    ];

    public function company()
    {
        return $this->belongsToMany('App\Company')->withPivot('worker_type');
    }

}

在我的 Controller 中,我调用了这样的保存方法:

$worker = New Worker;
$worker->name = "Jane Smith";

$company = Company::find($id);
$company->workers()->save($worker, ['worker_type' => 'contractor'];

根据 Laravel 和 Ardent 的文档,我正确地建立了我的关系,但 Ardent 抛出错误:ErrorException in Ardent.php line 821: Invalid argument supplied for foreach()

Ardent error message

是什么导致了这个错误?是我的代码还是 Ardent 的代码中的错误?

注意:我使用的是 Ardent 3.3.0 版本,当我回滚到 3.0.0 版本时问题消失

最佳答案

您尚未为扩展 Ardent 的一个或多个模型定义规则。

class Whatever extends \LaravelArdent\Ardent\Ardent {
   public static $rules = [];
}

专线821表明我们正在寻找一个我们找不到的名为 $ruleset 的数组。

关于php - Laravel Ardent 多对多关系抛出错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34802294/

相关文章:

php - Facebook OAuth,找不到页面

php - 在 PHP 中回显 HTML 的最佳方式

php - 在 codeigniter 中使用表单数据上传单个文件

mysql - 2 非常快速和简单的查询合并在一起时非常慢

php - 在 Laravel 中获取查询而不是按名称替换外键

php - 从数据库中选择所有以小写字母开头的字符串

mysql - 收到错误无法删除或更新父行 : a foreign key constraint fails even setting ON DELETE NO ACTION ON UPDATE NO ACTION

c# - MYSQL 计数或求和默认值

php - 单击 Livewire 上的添加按钮后表格消失

php - 无法使用 Laravel 连接到本地 MySQL 服务器