在Laravel框架中,$fillable
属性在模型(Model)中扮演着至关重要的角色。它是Laravel Eloquent ORM系统提供的一个安全特性,用于防止所谓的“批量赋值漏洞”(Mass Assignment Vulnerability)。本文将深入探讨 $fillable
的用途、如何使用它以及为何它如此重要。
$fillable
属性的用途
在日常开发过程中,我们经常需要从用户那里接收数据,并将这些数据保存到数据库中。Laravel提供了方便的批量赋值(Mass Assignment)功能,使得开发者可以一次性赋值多个属性。然而,这项功能如果没有适当的限制,也可能带来安全风险。攻击者可能会通过批量赋值漏洞,向数据库写入不应被修改的字段。为了解决这个问题,Laravel引入了 $fillable
属性,让我们定义哪些字段可以被批量赋值。
使用 $fillable
在Laravel的Eloquent模型中,$fillable
是一个数组,包含了可以被批量赋值的字段名。通过设置这个属性,任何不在该数组中的字段都不会被批量赋值,从而提高了应用程序的安全性。
举个例子,假设我们有一个 User
模型,包含 name
, email
, 和 password
字段。如果希望这三个字段都可以通过批量赋值来更新,则可以在 User
模型中设置如下:
class User extends Model
{
protected $fillable = ['name', 'email', 'password'];
}
现在,如果我们使用Eloquent的 create
方法或是在实例化模型后调用 fill
方法,只有在 $fillable
数组中列出的字段会被赋值。
$user = User::create([
'name' => 'John Doe',
'email' => 'john@example.com',
'password' => 'secret',
'is_admin' => 1 // 假设这是不希望通过用户输入直接赋值的字段
]);
由于 is_admin
字段没有在 $fillable
数组中指定,它不会被批量赋值,从而保证了数据的安全性。
$fillable
与 $guarded
Laravel提供了另外一个与 $fillable
对立的属性 $guarded
。与 $fillable
指定"哪些字段可以被批量赋值"不同,$guarded
指定的是"哪些字段不可以被批量赋值"。
一般情况下,应该只使用其中一种方法来保护你的模型,要么是 $fillable
,要么是 $guarded
。使用两者中的一种,根据具体场景和个人偏好选择最适合你的项目的那个。
结论
通过正确使用 $fillable
属性,开发者可以有效地保护应用免受批量赋值漏洞的影响。它使得只有指定的字段可以被外部用户输入影响,为应用数据的安全性提供了一道防线。在开发使用Laravel框架的应用时,恰当地设置 $fillable
或 $guarded
属性是一项最佳实践。