首页 > php框架 > Laravel > 正文

laravel API资源(Resource)如何格式化JSON输出_Laravel API资源JSON格式化方法

穿越時空
发布: 2025-10-08 13:27:02
原创
168人浏览过
Laravel API资源类可将Eloquent模型转为结构化JSON,通过UserResource的toArray方法自定义字段命名、格式化日期、添加计算属性,并嵌套PostResource处理关联数据,结合whenLoaded和when方法实现按需加载与条件输出,提升API安全性与可维护性。

laravel api资源(resource)如何格式化json输出_laravel api资源json格式化方法

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'),
];
登录后复制

处理关联数据

当需要包含关联模型时,可以嵌套其他资源类。比如用户有多个文章:

pollinations
pollinations

属于你的个性化媒体引擎

pollinations 231
查看详情 pollinations
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 更规范、更安全,也更容易维护。

以上就是laravel API资源(Resource)如何格式化JSON输出_Laravel API资源JSON格式化方法的详细内容,更多请关注php中文网其它相关文章!

最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号