laravel ORM序列化

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了laravel ORM序列化相关的知识,希望对你有一定的参考价值。

在laravel项目 常常需要把eloquent ORM序列化为数组或者json,Eloquent 提供了便捷方法以便实现这些转换,以及控制哪些属性被包含到序列化中。

1.序列化为数组

 $user = App\User::with(‘roles‘)->first();return $user->toArray();

2.序列化为json $user = App\User::find(1);return $user->toJson();

3.在json中隐藏属性 

在模型中定义$hidden属性 例如  protected $hidden = [‘password‘];

同理通过定义$visible 属性 来控制模型中模型数组或者json中的属性白名单。例如 protected $visible = [‘first_name‘, ‘last_name‘];

4.若要在模型中临时的暴露某个属性  return $user->makeVisible(‘attribute‘)->toArray();

5.若要追加数据库不存在的字段到数组或者json返回值时候 需要先定义一个访问器 

<?php

namespace App;

use Illuminate\Database\Eloquent\Model;

class User extends Model
{
    /**
     * 为用户获取管理员标识
     *
     * @return bool
     */
    public function getIsAdminAttribute()
    {
        return $this->attributes[‘admin‘] == ‘yes‘;
    }
}
定义好访问器后,添加字段名到该模型的 appends 属性
 protected $appends = [‘is_admin‘];








以上是关于laravel ORM序列化的主要内容,如果未能解决你的问题,请参考以下文章

laravel orm进行增删改查

如何简化 Laravel ORM

需要一种有效的方法来避免使用 Laravel 5 重复代码片段

是否可以在 laravel ORM 的增量中添加 tinyInteger 或 smallInteger?

Laravel Eloquent ORM - 获取第一个和第三个表数据

Laravel CRUD ORM 找不到模型