我是一名年轻的开发人员,我最近发现了Api-Platform来制作一个完整的 rest api。
目前,我正在关注文档,但我不明白如何通过示例获取一个人的所有书籍。
我在这里:
我自动生成了 Book 和 Person 实体,我只是在它们之间添加了 ManyToMany 关系。
然后我有以下结果:
得到api.platform.dev/app_dev.php/
{
@context: "/app_dev.php/contexts/Entrypoint",
@id: "/app_dev.php/",
@type: "Entrypoint",
person: "/app_dev.php/people",
book: "/app_dev.php/books"
}
得到api.platform.dev/app_dev.php/people/3
{
@context: "/app_dev.php/contexts/Person",
@id: "/app_dev.php/people/3",
@type: "http://schema.org/Person",
birthDate: null,
description: "test",
gender: "Femme",
name: "test",
url: null,
books: [
"/app_dev.php/books/1",
"/app_dev.php/books/4"
]
}
这是我的问题,我怎样才能在第二个结果中获得一个人所有书籍的超媒体,以及获得一个人的所有书籍的最佳选择是什么?
我已经开始创建我的自定义操作:
#services.yml
resource.person.item_operation.custom_get:
class: "Dunglas\ApiBundle\Api\Operation\Operation"
public: false
factory:
- "@api.operation_factory"
- "createItemOperation"
arguments:
- "@resource.person" # Resource
- ["GET"] # Methods
- "/people/{id}/books" # Path
- "AppBundle:Person:custom" # Controller
- "my_custom_route2" # Route name
- # Context (will be present in Hydra documentation)
"@type": "hydra:Operation"
"hydra:title": "A custom operation"
"returns": "xmls:string"
和
// PersonController.php
<?php
namespace AppBundle\Controller;
use Dunglas\ApiBundle\Controller\ResourceController;
use Symfony\Component\HttpFoundation\Request;
class PersonController extends ResourceController
{
public function customAction(Request $request, $id)
{
return parent::getAction($request, $id);
}
}
GETapi.platform.dev/app_dev.php/people/3/books
上的结果与基本相同api.platform.dev/app_dev.php/people/3
,正常我打电话给父母。
但是现在拥有这样的东西的最好方法是什么:
# GET api.platform.dev/app_dev.php/people/3/books
{
@context: "/app_dev.php/contexts/Book",
@id: "/app_dev.php/people/3/books",
@type: "hydra:PagedCollection",
hydra:totalItems: 2,
hydra:itemsPerPage: 30,
hydra:firstPage: "/app_dev.php/people/3/books",
hydra:lastPage: "/app_dev.php/people/3/books",
hydra:member: [
{
@id: "/app_dev.php/books/1",
@type: "http://schema.org/Book",
illustrator: [ ],
isbn: null,
numberOfPages: 1230,
author: [ ],
datePublished: null,
description: "Desription",
genre: null,
name: "someone",
publisher: null
},
{
@id: "/app_dev.php/books/2",
@type: "http://schema.org/Book",
illustrator: [ ],
isbn: null,
numberOfPages: 1230,
author: [ ],
datePublished: null,
description: "Desription",
genre: null,
name: "someone",
publisher: null
}
]
}
当我得到api.platform.dev/app_dev.php/people/3
这个 IRI/app_dev.php/people/3/books
谢谢你能给我的帮助。