laravel API资源(Resource)如何格式化JSON输出_Laravel API资源JSON格式化方法
发布时间 - 2025-10-08 00:00:00 点击率:次Laravel API资源类可将Eloquent模型转为结构化JSON,通过UserResource的toArray方法自定义字段命名、格式化日期、添加计算属性,并嵌套PostResource处理关联数据,结合whenLoaded和when方法实现按需加载与条件输出,提升API安全性与可维护性。
Laravel 的 API 资源(API Resources)提供了一种优雅的方式来将 Eloquent 模型转化为结构清晰的 JSON 响应。通过使用资源类,你可以精确控制返回给前端的数据格式,包括字段命名、嵌套关系、条件属性等。
创建 API 资源类
要格式化 JSON 输出,先为模型创建对应的资源类。例如,假设你有一个 User 模型:
php artisan make:resource UserResource这会生成一个 UserResource 类,位于 app/Http/Resources 目录下。该类中包含一个 toArray 方法,用于定义输出字段:
public function toArray($request)
{
return [
'id' => $this->id,
'name' => $this->name,
'email' => $this->email,
'created_at' => $this->created_at->toISOString(),
];
}
格式化字段与自定义属性
在 toArray 方法中,你可以重命名字段、添加计算属性或格式化日期:
- 将 user_name 替代原始的 name 字段
- 添加全名、头像 URL 等衍生数据
- 使用 Carbon 格式化时间
return [
'user_id' => $this->id,
'user_name' => $this->name,
'profile_image' => $this->avatar ? asset('storage/' . $this->avatar) : null,
'full_name' => "{$this->first_name} {$this->last_name}",
'registered_at' => $this->created_at->format('Y-m-d H:i:s'),
];
处理关联数据
当需要包含关联模型时,可以嵌套其他资源类。比如用户有多个文章:
use App\Http\Resources\PostResource;
return [
'id' => $this->id,
'name' => $this->name,
'posts' => PostResource::collection($this->whenLoaded('posts')),
];
whenLoaded 方法确保只有在关系被预加载时才包含数据,避免 N+1 查询问题。
条件性字段输出
某些字段可能只对特定用户可见,可用 when 方法实现条件输出:
'reset_token' => $this->when($request->user()->isAdmin(), $this->reset_token), 'email_verified' => $this->when($this->email_verified_at, true),
这样可防止敏感信息泄露,同时保持响应结构整洁。
基本上就这些。合理使用 Laravel 资源类,能让 API 返回的 JSON 更规范、更安全,也更容易维护。
# php
# laravel
# js
# 前端
# json
# app
# ai
# red
# carbon
# Resource
# http
# 你可以
# 自定义
# 加载
# 多个
# 你有
# 能让
# 可将
# 转化为
# 时才
# 只对
相关栏目:
【
网站优化151355 】
【
网络推广146373 】
【
网络技术251813 】
【
AI营销90571 】
相关推荐:
🚀拖拽式CMS建站能否实现高效与个性化并存?
小视频制作网站有哪些,有什么看国内小视频的网站,求推荐?
昵图网官方站入口 昵图网素材图库官网入口
javascript日期怎么处理_如何格式化输出
如何在阿里云服务器自主搭建网站?
什么是javascript作用域_全局和局部作用域有什么区别?
Bootstrap整体框架之CSS12栅格系统
简单实现jsp分页
Laravel任务队列怎么用_Laravel Queues异步处理任务提升应用性能
Bootstrap CSS布局之列表
Laravel如何使用API Resources格式化JSON响应_Laravel数据资源封装与格式化输出
网站广告牌制作方法,街上的广告牌,横幅,用PS还是其他软件做的?
如何做网站制作流程,*游戏网站怎么搭建?
微信小程序 五星评分(包括半颗星评分)实例代码
Laravel全局作用域是什么_Laravel Eloquent Global Scopes应用指南
小米17系列还有一款新机?主打6.9英寸大直屏和旗舰级影像
如何用y主机助手快速搭建网站?
如何快速查询网站的真实建站时间?
邀请函制作网站有哪些,有没有做年会邀请函的网站啊?在线制作,模板很多的那种?
如何在腾讯云服务器快速搭建个人网站?
Laravel怎么配置.env环境变量_Laravel生产环境敏感数据保护与读取【方法】
企业在线网站设计制作流程,想建设一个属于自己的企业网站,该如何去做?
Linux安全能力提升路径_长期防护思维说明【指导】
微信h5制作网站有哪些,免费微信H5页面制作工具?
如何为不同团队 ID 动态生成多个独立按钮
php中::能调用final静态方法吗_final修饰静态方法调用规则【解答】
如何在IIS7上新建站点并设置安全权限?
Laravel如何使用Blade模板引擎?(完整语法和示例)
Win11怎么关闭专注助手 Win11关闭免打扰模式设置【操作】
如何在云主机上快速搭建多站点网站?
如何打造高效商业网站?建站目的决定转化率
在线ppt制作网站有哪些软件,如何把网页的内容做成ppt?
php 三元运算符实例详细介绍
ChatGPT 4.0官网入口地址 ChatGPT在线体验官网
Windows10如何删除恢复分区_Win10 Diskpart命令强制删除分区
魔毅自助建站系统:模板定制与SEO优化一键生成指南
HTML5空格和margin有啥区别_空格与外边距的使用场景【说明】
Laravel如何生成PDF或Excel文件_Laravel文档导出工具与使用教程
Laravel如何使用Service Provider注册服务_Laravel服务提供者配置与加载
Laravel如何使用Eloquent进行子查询
Linux系统命令中tree命令详解
Laravel如何实现URL美化Slug功能_Laravel使用eloquent-sluggable生成别名【方法】
如何快速搭建安全的FTP站点?
胶州企业网站制作公司,青岛石头网络科技有限公司怎么样?
Win11怎么关闭资讯和兴趣_Windows11任务栏设置隐藏小组件
JavaScript如何实现倒计时_时间函数如何精确控制
Laravel如何自定义分页视图?(Pagination示例)
Win11怎么恢复误删照片_Win11数据恢复工具使用【推荐】
实例解析Array和String方法
Laravel中的Facade(门面)到底是什么原理


>when($this->email_verified_at, true),