当我浏览 Laravel Document about Eloquent ORM topic part时,我得到了一个新术语“Mass Assignment”。
文档显示如何进行批量分配和 $fillable
或 $guarded
属性设置。但是在经历了之后,我对“Mass Assignment”以及它是如何工作的并没有清楚的了解。
在我过去的 CodeIgniter 经验中,我也没有听说过这个术语。
有人对此有简单的解释吗?
最佳答案
批量分配是当您将数组发送到模型创建时,基本上是一次性在模型上设置一堆字段,而不是一个接一个,例如:
$user = new User(request()->all());
(这不是在模型上单独显式设置每个值。)
您可以使用 fillable
来保护您希望它实际允许更新的字段。
您还可以通过执行以下操作阻止所有字段可批量分配:
protected $guarded = ['*'];
假设在您的用户表中,您有一个字段是 user_type
并且可以具有 user/admin 的值
显然,您不希望用户能够更新此值。理论上,如果您使用上面的代码,有人可以为 user_type
注入(inject)一个新字段并将“admin”与其他表单数据一起发送,然后轻松地将他们的帐户切换为管理员帐户。 .. 坏消息。
通过添加:
$fillable = ['name', 'password', 'email'];
您确保只有那些值可以使用 mass assignment
为了能够更新 user_type
值,您需要在模型上显式设置并保存它,如下所示:
$user->user_type = 'admin';
$user->save();
关于php - "Mass Assignment"在 Laravel 中是什么意思?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22279435/