如何授权然后更新Laravel模型

时间:2018-01-03 13:50:40

标签: php laravel laravel-5.5

我正在调用此控制器来更新模型:

public function update(Request $request, $id)
  {
  $question = Question::find($id);
  $this->authorize('edit', $question); // uses Laravel's built-in Policy framework

  $updateArray = [
    'question' => $request->question,
    'type_based_id' => $request->type_based_id,
  ];

  //$question = Question::where('id', $id);
  $question = $question->update($updateArray);

  // Add the id into the array for return to the client
  $updateArray["id"] = $id;

  return ['message' => 'Question Updated', 'data' => $updateArray];

}

上面的代码在调用$question->update()时抛出了MassAssignmentException。如果我取消注释$question = Question::where('id', $id);它就可以了。

我做了一些日志记录,似乎find()返回了我的模型实例(App\Question),而where()返回了一个构建器(Illuminate\Database\Eloquent\Builder

如何在不进行两次单独的数据库请求的情况下同时满足authorize()和update()?

谢谢!

2 个答案:

答案 0 :(得分:1)

使用查询生成器的原因是因为它绕过了模型的批量分配检查。您正在运行自己的查询而不使用Model的更新方法。

问题:: where() - > update在Query Builder上调用update,而不是Model。

当您已经拥有要更新的模型实例时,没有理由使用查询构建器,但实际上并没有运行任何其他SQL查询。

MassAssignmentException通常表示您传递的属性之一在模型中受到保护。对于unguard属性,请从$guarded属性中删除它们,或将它们添加到模型的$fillable属性中。不要同时使用$ guarded和$ fillable,你必须使用其中一个。阅读完整的文档:

https://laravel.com/docs/5.5/eloquent#mass-assignment

答案 1 :(得分:0)

MassAssigntmentException是由于您正在更新的字段不是fillable,因此要保护其免于分配,要实现此目的,您需要在Question类上设置这些字段。

public class Question
{
    protected $fillable = [
        'question',
        'type_based_id',
    ];
}