信息发布→ 登录 注册 退出

Laravel模型访问器和修改器_Laravel Accessor和Mutator用法

发布时间:2025-11-26

点击量:
访问器用于格式化读取的属性值,修改器用于预处理写入的属性值。例如,通过getNameAttribute使name首字母大写,setEmailAttribute将email转为小写存储,实现数据展示与输入的灵活控制。

Laravel 的访问器(Accessor)和修改器(Mutator)是 Eloquent 模型中非常实用的功能,允许你在获取或设置模型属性时对其进行格式化或处理。它们能让你在不改变数据库存储方式的前提下,灵活控制数据的展示与输入。

什么是访问器(Accessor)

访问器用于在从数据库获取属性值时,对这个值进行格式化处理后再返回给调用方。比如将数据库中的时间戳转换为可读日期、将首字母大写等。

定义访问器的方法是:在模型中创建一个以 get{AttributeName}Attribute 命名的方法,其中 {AttributeName} 是你想处理的字段名,采用驼峰命名法。

示例:定义一个访问器,将 name 字段的值转为首字母大写

class User extends Model
{
    public function getNameAttribute($value)
    {
        return ucfirst($value);
    }
}

当你访问 $user->name 时,Laravel 会自动调用这个访问器,并返回处理后的值。

示例:将 created_at 格式化为“Y-m-d H:i”格式

public function getCreatedAtAttribute($value)
{
    return date('Y-m-d H:i', strtotime($value));
}

什么是修改器(Mutator)

修改器用于在将数据存入数据库之前,对属性值进行预处理。比如加密密码、统一字符串大小写、格式化日期等。

定义修改器的方法是:创建一个以 set{AttributeName}Attribute 命名的方法,参数是你传入的原始值。

示例:在保存前将 email 转为小写

class User extends Model
{
    public function setEmailAttribute($value)
    {
        $this->attributes['email'] = strtolower($value);
    }
}

示例:保存前对密码进行哈希加密

public function setPasswordAttribute($value)
{
    $this->attributes['password'] = bcrypt($value);
}

这样每次设置 password 属性时,都会自动加密存储,无需在控制器中手动处理。

使用场景建议

  • 敏感数据处理:如密码、身份证号的加密或脱敏显示
  • 格式统一:如手机号、邮箱标准化存储
  • 时间处理:将字符串自动转为 Carbon 实例,或格式化输出
  • 组合字段:通过访问器拼接多个字段,如获取 full_name = first_name + last_name
示例:组合字段访问器

public function getFullNameAttribute()
{
    return $this->first_name . ' ' . $this->last_name;
}

调用 $user->full_name 即可获取拼接结果。

注意事项

访问器和修改器只对通过 Eloquent 模型操作的数据生效。如果使用 DB 类直接操作数据库,这些方法不会被触发。

属性名遵循驼峰命名,在 URL 或数组中传递时应使用下划线命名(如 user_name),Laravel 会自动转换。

如果你在访问器中使用了不存在的属性,要确保该字段在模型的 $fillable 或 $guarded 中合理配置,避免被过滤。

基本上就这些。掌握 Accessor 和 Mutator 能让你的模型更智能,代码更整洁。
标签:# 访问器  # 你想  # 下划线  # 当你  # 多个  # 器中  # 创建一个  # 能让  # 首字母  # 你在  # 数据库  # laravel  # Attribute  # 字符串  # carbon  # 修改器  # 格式化输出  # 敏感数据  # 邮箱  # ai  # access  # word  
在线客服
服务热线

服务热线

4008888355

微信咨询
二维码
返回顶部
×二维码

截屏,微信识别二维码

打开微信

微信号已复制,请打开微信添加咨询详情!