侯体宗的博客
  • 首页
  • Hyperf版
  • beego仿版
  • 人生(杂谈)
  • 技术
  • 关于我
  • 更多分类
    • 文件下载
    • 文字修仙
    • 中国象棋ai
    • 群聊
    • 九宫格抽奖
    • 拼图
    • 消消乐
    • 相册

Laravel中的JSON API资源的构建及使用

Laravel  /  管理员 发布于 2年前   712

在Laravel中构建API是我的热情所在,我花了很多时间寻找完美的方式来返回一致的JSON:API友好资源,以便我可以找到并使用标准。

过去,我使用了一个拼凑而成的解决方案,几乎可以实现我所需要的,但这是一项相当多的工作。

这种方法的负面影响超过了好处,因为实现它所花费的开发时间感觉不值得。


幸运的是,Tim MacDonald 为这个用例构建了一个很棒的包。

它允许我们构建和返回易于使用的 JSON:API 兼容资源。

让我们来看看它是如何工作的。


通常在构建API资源时,我们会扩展LaravelJsonResource或CollectionResource取决于我们想要实现的目标。

我们的典型资源可能如下所示:

class PostResource extends JsonResource
{
    public function toArray($request): array
    {
        return [
            'id' => $this->id,
            'type' => 'post',
            'attributes' => [
                'title' => $this->title,
                'slug' => $this->slug,
                'content' => $this->content,
            ]
        ];
    }
}

我们正在添加一个简单的实现来“伪造”一个基本级别的 JSON:API 资源。

但正如你所看到的,这有点 - 糟糕。

让我们安装 Tim 的软件包:

composer require timacdonald/json-api

现在我们可以重构上述资源以遵循 JSON:API 标准。

让我带你了解这些变化。


首先,我们需要将扩展的类更改JsonResource为JsonApiResource:

class PostResource extends JsonApiResource

我们需要确保我们更改的下一件事是删除该toArray方法,

因为这个包将在后台为您处理这个 - 相反,我们使用对 JSON:API 标准有用的不同方法。

例如,要添加attributes到您的资源,您可以使用以下方法:

protected function toAttributes(Request $request): array
{
return [
'title' => $this->title,
                'slug' => $this->slug,
                'content' => $this->content,
];
}

现在让我们看看关系。

以前我们会做类似的事情:


 return [
   'id' => $this->id,
   'type' => 'post',
   'attributes' => [
   'title' => $this->title,
   'slug' => $this->slug,
   'content' => $this->content,
],
'relationships' => [
   'category' => new CategoryResource(
   resource: $this->whenLoaded('category'),
   ),
]
];

无论如何,这都不是一个坏方法。

但是,让我们看看如何将这些添加到 JSON:API 包中:

protected function toRelationships(Request $request): array
{
   return [
       'category' => fn () => new CategoryResource(
       resource: $this->category,
       ),
   ];
}

所以这一次,我们通过一个闭包进行评估以返回关系。

这是一种非常强大的方法,因为它使我们可以向关系加载添加非常自定义的行为——这意味着我们可以加载不同的条件关系或在资源上运行授权。

需要注意的另一点是,仅在客户端包含关系时才评估闭包 - 使其更清晰。


更进一步,添加指向您的 API 资源的链接是我认为重要的一步。

添加这些链接使您的 API 可导航,允许客户端根据需要以编程方式跟踪链接。

以前我会添加另一个数组条目来添加这些,并使用route助手来回显这些。

JSON:API 包有另一种方法,特别流畅:

protected function toLinks(Request $request): array
{
   return [
   Link::self(route('api:v1:posts:show', $this->resource)),
   ];
}

如您所见 - 它流畅、简单,并且会为您生成正确的链接。

当然,欢迎您在此处添加您需要的内容,但它会以 JSON:API 标准化方式添加链接 - 所以您不必这样做。


最后,元数据,在 JSON:API 中,您可以在其中添加其他信息,meta-object以便您可以添加文档链接或您可能需要通过 API 资源传回的任何内容(取决于您的 API 设计)。

没有一百万个用例,但该软件包确实支持它。

因此,让我们看一下以了解它。

protected function toMeta(Request $request): array
{
   return [
       'depreciated' => false,
       'docs' => 'https://docs.domain/com/resources/posts',
   ];
}

正如您在上面看到的,我们可以添加折旧警告,以便客户可以收到他们需要考虑更改的资源的通知 - 以及解释替换方法的文档链接。

您如何构建 API 资源?您是否遵循任何特定标准?在推特上告诉我们!


转:

https://laravel-news.com/json-api-resources-in-laravel

  • 上一条:
    介绍一款基于Golang的微信SDK开发框架:PowerWeChat SDK
    下一条:
    华尔街分析师:低市值加密货币就像低价股
  • 昵称:

    邮箱:

    0条评论 (评论内容有缓存机制,请悉知!)
    最新最热
    • 分类目录
    • 人生(杂谈)
    • 技术
    • linux
    • Java
    • php
    • 框架(架构)
    • 前端
    • ThinkPHP
    • 数据库
    • 微信(小程序)
    • Laravel
    • Redis
    • Docker
    • Go
    • swoole
    • Windows
    • Python
    • 苹果(mac/ios)
    • 相关文章
    • Laravel 11.15版本发布 - Eloquent Builder中添加的泛型(0个评论)
    • Laravel 11.14版本发布 - 新的字符串助手和ServeCommand改进(0个评论)
    • Laravel 11.12版本发布 - Artisan的`make`命令自动剪切`.php `扩展(0个评论)
    • Laravel的轻量型购物车扩展包:binafy/laravel-cart(0个评论)
    • Laravel 11.11版本发布 - 查看模型中的第三方关系:show(0个评论)
    • 近期文章
    • 在go+gin中使用"github.com/skip2/go-qrcode"实现url转二维码功能(0个评论)
    • 在go语言中使用api.geonames.org接口实现根据国际邮政编码获取地址信息功能(1个评论)
    • 在go语言中使用github.com/signintech/gopdf实现生成pdf分页文件功能(0个评论)
    • gmail发邮件报错:534 5.7.9 Application-specific password required...解决方案(0个评论)
    • 欧盟关于强迫劳动的规定的官方举报渠道及官方举报网站(0个评论)
    • 在go语言中使用github.com/signintech/gopdf实现生成pdf文件功能(0个评论)
    • Laravel从Accel获得5700万美元A轮融资(0个评论)
    • 在go + gin中gorm实现指定搜索/区间搜索分页列表功能接口实例(0个评论)
    • 在go语言中实现IP/CIDR的ip和netmask互转及IP段形式互转及ip是否存在IP/CIDR(0个评论)
    • PHP 8.4 Alpha 1现已发布!(0个评论)
    • 近期评论
    • 122 在

      学历:一种延缓就业设计,生活需求下的权衡之选中评论 工作几年后,报名考研了,到现在还没认真学习备考,迷茫中。作为一名北漂互联网打工人..
    • 123 在

      Clash for Windows作者删库跑路了,github已404中评论 按理说只要你在国内,所有的流量进出都在监控范围内,不管你怎么隐藏也没用,想搞你分..
    • 原梓番博客 在

      在Laravel框架中使用模型Model分表最简单的方法中评论 好久好久都没看友情链接申请了,今天刚看,已经添加。..
    • 博主 在

      佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 @1111老铁这个不行了,可以看看近期评论的其他文章..
    • 1111 在

      佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 网站不能打开,博主百忙中能否发个APP下载链接,佛跳墙或极光..
    • 2016-10
    • 2016-11
    • 2017-07
    • 2017-08
    • 2020-03
    • 2020-04
    • 2020-05
    • 2020-06
    • 2020-07
    • 2020-08
    • 2020-09
    • 2020-10
    • 2020-11
    • 2021-01
    • 2021-02
    • 2021-03
    • 2021-04
    • 2021-05
    • 2021-06
    • 2021-07
    • 2021-08
    • 2021-09
    • 2021-10
    • 2021-11
    • 2021-12
    • 2022-01
    • 2022-02
    • 2022-03
    • 2022-04
    • 2022-05
    • 2022-06
    • 2022-07
    • 2022-08
    • 2022-09
    • 2022-10
    • 2022-11
    • 2022-12
    • 2023-01
    • 2023-02
    • 2023-03
    • 2023-04
    • 2023-05
    • 2023-06
    • 2023-07
    • 2023-08
    • 2023-09
    • 2023-10
    • 2023-11
    • 2023-12
    • 2024-01
    • 2024-02
    • 2024-03
    • 2024-04
    • 2024-05
    • 2024-06
    • 2024-07
    Top

    Copyright·© 2019 侯体宗版权所有· 粤ICP备20027696号 PHP交流群

    侯体宗的博客