返回介绍

16.4.10 交换资源

发布于 2024-08-17 00:45:49 字数 2447 浏览 0 评论 0 收藏 0

到目前为止,我们已经看到RestTemplate的各种方法来GRT、PUT、DELETE以及POST资源。在它们之中,我们看到两个特殊的方法:getForEntity()和postForEntity(),这两个方法将结果资源包含在一个ResponseEntity对象中,通过这个对象我们可以得到响应头和状态码。

能够从响应中读取头信息是很有用的。但是如果你想在发送给服务端的请求中设置头信息的话,怎么办呢?这就是RestTemplate的exchange()的用武之地。

像RestTemplate的其他方法一样,exchange()也重载为三个签名格式。一个使用java.net.URI来标识目标URL,而其他两个以String的形式传入URL并带有URL变量。如下所示:

exchange()方法使用HttpMethod参数来表明要使用的HTTP动作。根据这个参数的值,exchange()能够执行与其他RestTemplate方法一样的工作。

例如,从服务器端获取Spitter资源的一种方式是使用RestTemplate的getForEntity()方法,如下所示:

在下面的代码片段中,可以看到exchange()也可以完成这项任务:

通过传入HttpMethod.GET作为HTTP动作,我们会要求exchange()发送一个GET请求。第三个参数是用于在请求中发送资源的,但因为这是一个GET请求,它可以是null。下一个参数表明我们希望将响应转换为Spitter对象。最后一个参数用于替换URL模板中{spitter}占位符的值。

按照这种方式,exchange()与之前使用的getForEntity()是几乎相同的,但是,不同于getForEntity()——或getForObject()——exchange()方法允许在请求中设置头信息。接下来,我们不再给exchange()传递null,而是传入带有请求头信息的HttpEntity。

如果不指明头信息,exchange()对Spitter的GET请求会带有如下的头信息:

让我们看一下Accept头信息。Accept头信息表明它能够接受多种不同的XML内容类型以及application/json。这样服务器端在决定采用哪种格式返回资源时,就有很大的可选空间。假设我们希望服务端以JSON格式发送资源。在这种情况下,我们需要将“application/json”设置为Accept头信息的唯一值。

设置请求头信息是很简单的,只需构造发送给exchange()方法的HttpEntity对象即可,HttpEntity中包含承载头信息的MultiValueMap:

在这里,我们创建了一个LinkedMultiValueMap并添加值为“application/json”的Accept头信息。接下来,我们构建了一个HttpEntity(使用Object泛型类型),将MultiValueMap作为构造参数传入。如果这是一个PUT或POST请求,我们需要为HttpEntity设置在请求体中发送的对象——对于GET请求来说,这是没有必要的。

现在,我们可以传入HttpEntity来调用exchange():

表面上看,结果是一样的。我们得到了请求的Spitter对象。但在表面之下,请求将会带有如下的头信息发送:

假设服务器端能够将Spitter序列化为JSON,响应体将会以JSON格式来进行表述。

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
列表为空,暂无数据
    我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
    原文