作者:独坤2602884605 | 来源:互联网 | 2023-09-14 18:27
Spring HATEOAS和Spring Data Commons中将支持这种情况。Spring
HATEOAS附带了一个PageMetadata
对象,该对象本质上包含与a 相同的数据,Page
但执行方式较少,因此可以更轻松地将其编组和拆组。
我们将其与Spring HATEOAS和Spring Data
commons结合实现的原因的另一方面是,仅对页面,其内容和元数据进行封送处理并没有价值,但是还希望生成指向可能存在的下一页或上一页的链接,因此客户端不必构造URI即可遍历这些页面本身。
一个例子
假设一个域类Person
:
class Person {
Long id;
String firstname, lastname;
}
以及相应的存储库:
interface PersonRepository extends PagingAndSortingRepository { }
现在,您可以公开一个Spring MVC控制器,如下所示:
@Controller
class PersonController {
@Autowired PersonRepository repository;
@RequestMapping(value = "/persons", method = RequestMethod.GET)
HttpEntity> persons(Pageable pageable,
PagedResourcesAssembler assembler) {
Page persOns= repository.findAll(pageable);
return new ResponseEntity<>(assembler.toResources(persons), HttpStatus.OK);
}
}
这里可能有很多解释。让我们逐步进行:
- 我们有一个Spring MVC控制器,将存储库连接到其中。这需要设置Spring Data(通过
@Enable(Jpa|Mongo|Neo4j|Gemfire)Repositories
XML等效项)。该controller方法映射到/persons
,这意味着它将接受GET
对该方法的所有请求。
- 从该方法返回的核心类型是a
PagedResources
-Spring HATEOAS的类型,它表示一些内容中带有Links
加号的内容PageMetadata
。
- 调用该方法时,Spring MVC将必须为
Pageable
和创建实例PagedResourcesAssembler
。为了使此工作正常进行,您需要通过@EnableSpringDataWebSupport
即将在Spring Data Commons里程碑中引入的注释或通过独立的bean定义(在此处记录)来启用Spring Data Web支持。
该Pageable
会从请求信息来填充。默认配置将转向?page=0&size=10
成Pageable
由10个页面大小请求的第一页。
将PageableResourcesAssembler
让你轻松转Page
成一个PagedResources
实例。它将不仅将页面元数据添加到响应中,还将根据您访问的页面以及如何Pageable
配置分辨率将适当的链接添加到表示中。
为JPA启用此功能的示例JavaConfig配置如下所示:
@Configuration
@EnableWebMvc
@EnableSpringDataWebSupport
@EnableJpaRepositories
class Applicationconfig {
// declare infrastructure components like EntityManagerFactory etc. here
}
样本请求和响应
假设Persons
数据库中有30个。现在,您可以触发一个请求GET
http://localhost:8080/persons
,您将看到类似以下内容:
{ "links" : [
{ "rel" : "next", "href" : "http://localhost:8080/persons?page=1&size=20 }
],
"content" : [
… // 20 Person instances rendered here
],
"pageMetadata" : {
"size" : 20,
"totalElements" : 30,
"totalPages" : 2,
"number" : 0
}
}
请注意,汇编器生成了正确的URI,并且还采用了当前的默认配置来将参数解析Pageable
为即将到来的请求。这意味着,如果您更改该配置,则链接将自动遵守更改。默认情况下,汇编器指向调用该方法的控制器方法,但可以通过传递一个自定义Link
来对其进行自定义,该自定义用作构建该PagedResourcesAssembler.toResource(…)
方法重载的分页链接的基础。
外表
这些PagedResourcesAssembler
位将在Spring Data Babbage发布系列的即将发布的里程碑版本中提供。当前快照中已提供该功能。您可以在我的Spring RESTBucks示例应用程序中看到一个有效的示例。只需将其克隆,运行mvn
jetty:run
并卷曲即可http://localhost:8080/pages
。