Spring认证中国教育管理中心-Spring Data REST框架教程二

简介: Spring认证中国教育管理中心-Spring Data REST框架教程二

原标题:Spring认证中国教育管理中心-Spring Data REST框架教程二(Spring中国教育管理中心)

4.2.馆藏资源
Spring Data REST 公开了一个以导出存储库正在处理的域类的非大写复数版本命名的集合资源。资源的名称和路径都可以通过@RepositoryRestResource在存储库界面上使用来自定义。

4.2.1.支持的 HTTP 方法
集合资源同时支持GET和POST. 所有其他 HTTP 方法都会导致405 Method Not Allowed.

GET
通过其findAll(…)方法返回存储库服务器的所有实体。如果存储库是分页存储库,我们会在必要时包含分页链接和其他页面元数据。

用于调用的方法
如果存在,则使用以下方法(降序):

findAll(Pageable)
findAll(Sort)
findAll()
有关方法默认公开的更多信息,请参阅存储库方法公开。

参数
如果存储库具有分页功能,则资源采用以下参数:

page: 要访问的页码(0 索引,默认为 0)。
size:请求的页面大小(默认为 20)。
sort: 格式为($propertyname,)+[asc|desc]?的排序指令的集合。
自定义状态代码
该GET方法只有一个自定义状态代码:

405 Method Not Allowed:如果findAll(…)方法未导出(通过@RestResource(exported = false))或不存在于存储库中。
支持的媒体类型
该GET方法支持以下媒体类型:

application/hal+json
application/json
相关资源
该GET方法支持用于发现相关资源的单个链接:

search:如果后备存储库公开查询方法,则公开搜索资源。
HEAD
该HEAD方法返回集合资源是否可用。它没有状态代码、媒体类型或相关资源。

用于调用的方法
如果存在,则使用以下方法(降序):

findAll(Pageable)
findAll(Sort)
findAll()
有关方法默认公开的更多信息,请参阅存储库方法公开。

POST
该POST方法从给定的请求正文创建一个新实体。默认情况下,响应是否包含正文由Accept随请求发送的标头控制。如果发送了一个,则会创建一个响应正文。如果不是,则响应正文为空,并且可以通过以下Location响应标头中包含的链接获取所创建资源的表示。可以通过相应的配置来覆盖此行为
RepositoryRestConfiguration.setReturnBodyOnCreate(…)。

用于调用的方法
如果存在,则使用以下方法(降序):

save(…)
有关方法默认公开的更多信息,请参阅存储库方法公开。

自定义状态代码
该POST方法只有一个自定义状态代码:

405 Method Not Allowed:如果save(…)方法未导出(通过@RestResource(exported = false))或根本不存在于存储库中。
支持的媒体类型
该POST方法支持以下媒体类型:

应用程序/hal+json
应用程序/json
4.3.物品资源
Spring Data REST 将单个集合项的资源公开为集合资源的子资源。

4.3.1.支持的 HTTP 方法
项目资源通常支持GET、PUT、PATCH和DELETE,除非显式配置阻止(请参阅“关联资源”了解详细信息)。

得到
该GET方法返回单个实体。

用于调用的方法
如果存在,则使用以下方法(降序):

findById(…)
有关方法默认公开的更多信息,请参阅存储库方法公开。

自定义状态代码
该GET方法只有一个自定义状态代码:

405 Method Not Allowed:如果findOne(…)方法未导出(通过@RestResource(exported = false))或不存在于存储库中。
支持的媒体类型
该GET方法支持以下媒体类型:

应用程序/hal+json
应用程序/json
相关资源
对于域类型的每个关联,我们公开以关联属性命名的链接。您可以通过@RestResource在属性上使用来自定义此行为。相关资源为关联资源类型。

HEAD
该HEAD方法返回项目资源是否可用。它没有状态代码、媒体类型或相关资源。

用于调用的方法
如果存在,则使用以下方法(降序):

findById(…)
有关方法默认公开的更多信息,请参阅存储库方法公开。

PUT
该PUT方法用提供的请求正文替换目标资源的状态。默认情况下,响应是否包含正文由Accept随请求发送的标头控制。如果请求标头存在,200 OK则返回响应正文和状态代码。如果不存在标头,则响应正文为空,并且成功的请求将返回 状态204 No Content。可以通过相应的配置来覆盖此行为
RepositoryRestConfiguration.setReturnBodyOnUpdate(…)。

用于调用的方法
如果存在,则使用以下方法(降序):

save(…)
有关方法默认公开的更多信息,请参阅存储库方法公开。

自定义状态代码
该PUT方法只有一个自定义状态代码:

405 Method Not Allowed:如果save(…)方法未导出(通过@RestResource(exported = false))或根本不存在于存储库中。
支持的媒体类型
该PUT方法支持以下媒体类型:

应用程序/hal+json
应用程序/json
PATCH
该PATCH方法与方法类似,PUT但部分更新资源状态。

用于调用的方法
如果存在,则使用以下方法(降序):

save(…)
有关方法默认公开的更多信息,请参阅存储库方法公开。

自定义状态代码
该PATCH方法只有一个自定义状态代码:

405 Method Not Allowed:如果save(…)方法未导出(通过@RestResource(exported = false))或不存在于存储库中。
支持的媒体类型
该PATCH方法支持以下媒体类型:

应用程序/hal+json
应用程序/json
应用程序/补丁+json
应用程序/合并补丁+json
DELETE
该DELETE方法删除暴露的资源。

用于调用的方法
如果存在,则使用以下方法(降序):

delete(T)
delete(ID)
delete(Iterable)
有关方法默认公开的更多信息,请参阅存储库方法公开。

自定义状态代码
该DELETE方法只有一个自定义状态代码:

405 Method Not Allowed:如果delete(…)方法未导出(通过@RestResource(exported = false))或不存在于存储库中。
4.4.协会资源
Spring Data REST 为每个项目资源具有的每个关联公开每个项目资源的子资源。资源的名称和路径默认为关联属性的名称,可以在关联属性上使用自定义@RestResource。

4.4.1.支持的 HTTP 方法
关联资源支持以下媒体类型:

得到

邮政
删除
GET
该GET方法返回关联资源的状态。

支持的媒体类型
该GET方法支持以下媒体类型:

应用程序/hal+json
应用程序/json
PUT
该PUT方法将给定 URI 指向的资源绑定到关联资源(请参阅支持的媒体类型)。

自定义状态代码
该PUT方法只有一个自定义状态代码:

400 Bad Request:当为一对一关联提供多个 URI 时。
支持的媒体类型
该PUT方法仅支持一种媒体类型:

text/uri-list:指向要绑定到关联的资源的 URI。
POST
该POST方法仅支持集合关联。它向集合中添加了一个新元素。

支持的媒体类型
该POST方法仅支持一种媒体类型:

text/uri-list:指向要添加到关联的资源的 URI。
DELETE
该DELETE方法解除关联。

自定义状态代码
该POST方法只有一个自定义状态代码:

405 Method Not Allowed:当关联是非可选的。
4.5.搜索资源
搜索资源返回存储库公开的所有查询方法的链接。可以使用@RestResource方法声明来修改查询方法资源的路径和名称。

4.5.1.支持的 HTTP 方法
由于搜索资源是只读资源,所以只支持该GET方法。

GET
该GET方法返回指向各个查询方法资源的链接列表。

支持的媒体类型
该GET方法支持以下媒体类型:

应用程序/hal+json
应用程序/json
相关资源
对于存储库中声明的每个查询方法,我们公开一个查询方法资源。如果资源支持分页,则指向它的 URI 是包含分页参数的 URI 模板。

HEAD
该HEAD方法返回搜索资源是否可用。404 返回码表示没有可用的查询方法资源。

4.6.查询方法资源
查询方法资源通过存储库界面上的单个查询方法运行公开的查询。

4.6.1.支持的 HTTP 方法
由于查询方法资源是只读资源,所以GET只支持。

GET
该GET方法返回查询的结果。

参数
如果查询方法具有分页功能(在指向资源的 URI 模板中指示),则资源采用以下参数:

page: 要访问的页码(0 索引,默认为 0)。
size:请求的页面大小(默认为 20)。
sort: 格式为($propertyname,)+[asc|desc]?的排序指令的集合。
支持的媒体类型
该GET方法支持以下媒体类型:

application/hal+json
application/json
HEAD
该HEAD方法返回查询方法资源是否可用。

  1. 分页和排序

本节记录了 Spring Data REST 对 Spring Data Repository 分页和排序抽象的使用。要熟悉这些功能,请参阅您使用的存储库实现(例如 Spring Data JPA)的 Spring Data 文档。

5.1.分页
Spring Data REST 不是从大型结果集中返回所有内容,而是识别一些影响页面大小和起始页码的 URL 参数。

如果您扩展
PagingAndSortingRepository<T, ID>并访问所有实体的列表,您将获得前 20 个实体的链接。要将页面大小设置为任何其他数字,请添加一个size参数,如下所示:

http://localhost:8080/people/?size=5
前面的示例将页面大小设置为 5。

要在您自己的查询方法中使用分页,您需要更改方法签名以接受附加Pageable参数并返回 aPage而不是 a List。比如下面的查询方法导出到
/people/search/nameStartsWith并支持分页:

@RestResource(path = "nameStartsWith", rel = "nameStartsWith")
public Page findByNameStartsWith(@Param("name") String name, Pageable p);
Spring Data REST 导出器识别返回Page并在响应正文中为您提供结果,就像处理非分页响应一样,但会向资源添加额外的链接以表示数据的上一页和下一页。

5.1.1.上一个和下一个链接
每个分页响应使用 IANA 定义的链接关系prev和next. 但是,如果您当前位于结果的第一页,则不会prev呈现任何链接。对于结果的最后一页,不next呈现链接。

考虑以下示例,我们将页面大小设置为 5:

{
"_links" : {

"self" : {
  "href" : "http://localhost:8080/persons{&sort,page,size}", 
  "templated" : true
},
"next" : {
  "href" : "http://localhost:8080/persons?page=1&size=5{&sort}", 
  "templated" : true
}

},
"_embedded" : {

  … data …

},
"page" : {

"size" : 5,
"totalElements" : 50,
"totalPages" : 10,
"number" : 0

}
}
在顶部,我们看到_links:

该self链接为整个系列提供了一些选项。

该next链接指向下一页,假设页面大小相同。

底部是有关页面设置的额外数据,包括页面大小、总元素、总页数以及您当前查看的页码。

Spring认证中国教育管理中心-Spring Data REST框架教程二
使用curl命令行等工具时,如果&语句中有“&”( ),则需要将整个URI用引号括起来。

请注意,self和nextURI 实际上是 URI 模板。它们不仅接受size, 还接受page和sort作为可选标志。

如前所述,HAL 文档的底部包含有关该页面的详细信息集合。这些额外信息使您可以轻松配置滑块或指示器等 UI 工具,以反映用户在查看数据时的整体位置。例如,前面示例中的文档显示我们正在查看第一页(页码从 0 开始)。

以下示例显示了当我们点击next链接时会发生什么:

$ curl "http://localhost:8080/persons?page=1&size=5"
{
"_links" : {

"self" : {
  "href" : "http://localhost:8080/persons{&sort,projection,page,size}",
  "templated" : true
},
"next" : {
  "href" : "http://localhost:8080/persons?page=2&size=5{&sort,projection}", 
  "templated" : true
},
"prev" : {
  "href" : "http://localhost:8080/persons?page=0&size=5{&sort,projection}", 
  "templated" : true
}

},
"_embedded" : {

... data ...

},
"page" : {

"size" : 5,
"totalElements" : 50,
"totalPages" : 10,
"number" : 1 

}
}
这看起来非常相似,除了以下差异:

该next链接现在指向另一个页面,表明它与self链接的相对视角。

prev现在出现一个链接,为我们提供上一页的路径。

当前编号现在是 1(表示第二页)。

Spring认证中国教育管理中心-Spring Data REST框架教程二
此功能可让您将屏幕上的可选按钮映射到这些超媒体控件,让您无需对 URI 进行硬编码即可实现 UI 体验的导航功能。事实上,用户可以从页面大小列表中进行选择,动态更改所提供的内容,而无需next在顶部或底部重写和`prev 控件。

相关文章
|
11天前
|
SQL Java 数据库连接
对Spring、SpringMVC、MyBatis框架的介绍与解释
Spring 框架提供了全面的基础设施支持,Spring MVC 专注于 Web 层的开发,而 MyBatis 则是一个高效的持久层框架。这三个框架结合使用,可以显著提升 Java 企业级应用的开发效率和质量。通过理解它们的核心特性和使用方法,开发者可以更好地构建和维护复杂的应用程序。
92 29
|
26天前
|
开发框架 运维 监控
Spring Boot中的日志框架选择
在Spring Boot开发中,日志管理至关重要。常见的日志框架有Logback、Log4j2、Java Util Logging和Slf4j。选择合适的日志框架需考虑性能、灵活性、社区支持及集成配置。本文以Logback为例,演示了如何记录不同级别的日志消息,并强调合理配置日志框架对提升系统可靠性和开发效率的重要性。
|
2月前
|
设计模式 XML Java
【23种设计模式·全精解析 | 自定义Spring框架篇】Spring核心源码分析+自定义Spring的IOC功能,依赖注入功能
本文详细介绍了Spring框架的核心功能,并通过手写自定义Spring框架的方式,深入理解了Spring的IOC(控制反转)和DI(依赖注入)功能,并且学会实际运用设计模式到真实开发中。
【23种设计模式·全精解析 | 自定义Spring框架篇】Spring核心源码分析+自定义Spring的IOC功能,依赖注入功能
|
2月前
|
Java 开发者 Spring
理解和解决Spring框架中的事务自调用问题
事务自调用问题是由于 Spring AOP 代理机制引起的,当方法在同一个类内部自调用时,事务注解将失效。通过使用代理对象调用、将事务逻辑分离到不同类中或使用 AspectJ 模式,可以有效解决这一问题。理解和解决这一问题,对于保证 Spring 应用中的事务管理正确性至关重要。掌握这些技巧,可以提高开发效率和代码的健壮性。
109 13
|
2月前
|
IDE Java 测试技术
互联网应用主流框架整合之Spring Boot开发
通过本文的介绍,我们详细探讨了Spring Boot开发的核心概念和实践方法,包括项目结构、数据访问层、服务层、控制层、配置管理、单元测试以及部署与运行。Spring Boot通过简化配置和强大的生态系统,使得互联网应用的开发更加高效和可靠。希望本文能够帮助开发者快速掌握Spring Boot,并在实际项目中灵活应用。
65 5
|
2月前
|
安全 Java 数据安全/隐私保护
基于内存认证的 Spring Security
通过本文的介绍,希望您能够深入理解基于内存认证的Spring Security配置与使用方法,并能够在实际开发中灵活应用这一技术,提升应用的安全性和用户体验。
65 9
|
2月前
|
缓存 Java 数据库连接
Spring框架中的事件机制:深入理解与实践
Spring框架是一个广泛使用的Java企业级应用框架,提供了依赖注入、面向切面编程(AOP)、事务管理、Web应用程序开发等一系列功能。在Spring框架中,事件机制是一种重要的通信方式,它允许不同组件之间进行松耦合的通信,提高了应用程序的可维护性和可扩展性。本文将深入探讨Spring框架中的事件机制,包括不同类型的事件、底层原理、应用实践以及优缺点。
84 8
|
Java API Spring
Spring认证_Spring GraphQL
Spring GraphQL项目的创建以及面向 1.0 版本的初始里程碑的可用性。该项目集成了GraphQL Java和 Spring,并由两个团队合作开发。
Spring认证_Spring GraphQL
|
21天前
|
XML Java 应用服务中间件
Spring Boot 两种部署到服务器的方式
本文介绍了Spring Boot项目的两种部署方式:jar包和war包。Jar包方式使用内置Tomcat,只需配置JDK 1.8及以上环境,通过`nohup java -jar`命令后台运行,并开放服务器端口即可访问。War包则需将项目打包后放入外部Tomcat的webapps目录,修改启动类继承`SpringBootServletInitializer`并调整pom.xml中的打包类型为war,最后启动Tomcat访问应用。两者各有优劣,jar包更简单便捷,而war包适合传统部署场景。需要注意的是,war包部署时,内置Tomcat的端口配置不会生效。
158 17
Spring Boot 两种部署到服务器的方式
|
21天前
|
Dart 前端开发 JavaScript
springboot自动配置原理
Spring Boot 自动配置原理:通过 `@EnableAutoConfiguration` 开启自动配置,扫描 `META-INF/spring.factories` 下的配置类,省去手动编写配置文件。使用 `@ConditionalXXX` 注解判断配置类是否生效,导入对应的 starter 后自动配置生效。通过 `@EnableConfigurationProperties` 加载配置属性,默认值与配置文件中的值结合使用。总结来说,Spring Boot 通过这些机制简化了开发配置流程,提升了开发效率。
55 17
springboot自动配置原理