4种Springboot RestTemplate 服务里发送HTTP请求用法
摘要: RestTemplate与REST资源交互的方法涵盖了HTTP请求方法,包括get, post, put, delete。
本文分享自华为云社区《Springboot RestTemplate 服务里发送HTTP请求及几种用法的介绍》,作者:gentle_zhou。
在微服务如此流行的当下,专门为某项功能开发模块作为另一项功能的构建块就变得异常重要。假设我们的服务A是调用某个API接口,服务B则专门用来校验用户是否有权限,那么知道如何在服务A发送http请求去调用服务B的接口就很必要。
如果刚好我们的项目是用Java开发的,那么RestTemplate就是我们需要的可以提供便捷访问远程Http服务方法的类。我们先去官网看下RestTemplate类是在哪个包下:

可以看到是在spring框架网页客户端下,官网对它的介绍:
"Synchronous client to perform HTTP requests, exposing a simple, template method API over underlying HTTP client libraries such as the JDK HttpURLConnection, Apache HttpComponents, and others.
The RestTemplate offers templates for common scenarios by HTTP method, in addition to the generalized exchange and execute methods that support of less frequent cases."
翻译过来就是同步客户端来执行HTTP请求,暴露一个简单的模板方法API给底层的HTTP客户端库比如JDK HttpURLConnection、Apache HttpComponents。
RestTemplate通过HTTP方法为常见的场景提供了模板,除此之外,还提供了通用的交换和执行方法来支持不太常见的情况。
【如何创建?】
因为RestTemplate是Spring的封装;我们先去pom.xml文件里引入springboot starter web依赖,内含spring-web-X.X.X.RELEASE.jar包:
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
再去官网看看构建的介绍:

我们可以用官网给的这三种方式来创建RestTemplate。一般来说我们用第一种方式就可以了:
RestTemplate restTemplate = new RestTemplate();
在这个创建过程,RestTemplate默认使用HttpMessageConverter实例将HTTP消息转换成POJO(Plain Ordinary Java Object,即普通的没有使用Entity Beans的Java 对象)或则从POJO转换成HTTP消息。
RestTemplate与REST资源交互的方法涵盖了HTTP请求方法,包括get, post, put, delete。
【Get请求】
在RestTemplate里,有两种方式可以发送Get请求:
1.getForEntity(),发送HTTP GET请求,返回ResponseEntity包含相应体所映射成的对象。官方对该函数的解释如下:

首先是需要三个参数:url(要调用的服务的地址),返回值的类型和包含uri模板值的map 以及 最后会返回ResponseEntity<T>(是Spring对HTTP请求相应的封装,包含了几个重要的元素比如响应码,内容类型,内容长度和响应消息体)。
当然该函数的参数也可以是"url,返回值的类型,扩展模板的变量" / "url,返回值的类型"。
举个例子,我下面用的参数就是"url,返回值的类型,扩展模板的变量":
String accessToken = "fakeAT";
RestTemplate restTemplate = new RestTemplate();
String result = restTemplate.getForEntity("http://127.0.0.1:8880/getUserInfoById?accessToken={at}",
String.class, accessToken).getBody();
getBody()可以得到ResponseEntity<T>里面的响应消息体。
2.getForObject(),发送HTTP GET请求,返回映射的对象。官方对该函数的解释如下:

该方法也是需要三个参数:url,返回值的类型和包含uri模板值的map 以及 最后会返回T。
当然该函数的参数也可以是"url,返回值的类型,扩展模板的变量" / "url,返回值的类型"。
最后返回的T 实际上是对上一种方法返回的值ResponseEntity<T>的进一步封装,返回的是响应消息体里面的内容。
【Post请求】
在RestTemplate里,有三种方式可以发送Post请求:
1.postForEntity(),发送HTTP POST请求,返回ResponseEntity包含相应体所映射成的对象。官方对该函数的解释如下:

首先是需要三个参数:url,需要POST上去的对象(可以是null) 和扩展模板的变量 以及 最后会返回ResponseEntity<T>。
当然该函数的参数也可以是"url,需要POST上去的对象(可以是null),响应消息的类型,包含uri模板值的map" / "url,需要POST上去的对象(可以是null),响应消息的类型"。
2.postForObject(),发送HTTP POST请求,返回映射的对象。官方对该函数的解释如下:

首先是需要三个参数:url,需要POST上去的对象(可以是null) 和扩展模板的变量 以及 最后会返回ResponseEntity<T>。
当然该函数的参数也可以是"url,需要POST上去的对象(可以是null),响应消息的类型,包含uri模板值的map" / "url,需要POST上去的对象(可以是null),响应消息的类型"。
3.postForLocation(),发送HTTP POST请求,返回的是URI(提交POST之后,新资源的URI链接)。官方对该函数的解释如下:

首先是需要三个参数:url,需要POST上去的对象(可以是null) 和扩展模板的变量 以及 最后会返回URL(提交POST之后,新资源的URI链接)。
当然该函数的参数也可以是"url,需要POST上去的对象(可以是null),响应消息的类型,包含uri模板值的map" / "url,需要POST上去的对象(可以是null)"。
【Put请求】
put和post作用类似,只是后一个请求会把前一个请求覆盖,所以会被用来更改资源,POST则是用来增加资源。
在RestTemplate里,有1种方式可以发送Put请求:
1.put(),发送HTTP PUT请求,是void函数不返回内容。官方对该函数的解释如下:

首先是需要三个参数:url,需要PUT上去的对象(可以是null) 和扩展模板的变量,最后不会返回什么。做的事就是更改需要PUT上去的对象至URL指定的资源。
当然该函数的参数也可以是"url,需要PUT上去的对象(可以是null),包含uri模板值的map" / "url,需要PUT上去的对象(可以是null)"。
【Delete请求】
在RestTemplate里,有1种方式可以发送Delete请求:
1.delete(),发送HTTP DELETE请求,是void函数不返回内容。官方对该函数的解释如下:

首先是需要2个参数:url和扩展模板的变量,最后不会返回什么。做的事就是直接删除URL指定的资源。
当然该函数的参数也可以是"url,包含uri模板值的map" / "url"。
【Exchange方法和Execute方法】
1.exchange(),在URL上执行特定的HTTP方法,返回从响应体中映射得到的包含对象的ResponseEntity。
该方法可以指定请求的HTTP类型。对指定的URI模板执行HTTP方法,把指定的请求实体写入请求,并返回ResponseEntity响应。
官方对该函数的解释如下:

首先是需要5个参数:url,指定的HTTP方法(比如POST, GET),需要写入请求的实体(头部和主体 或 头部 或 主体,也可以是null) ,响应消息的类型和扩展模板的变量 以及 最后会返回ResponseEntity<T>。
当然该函数的参数也可以是"url,指定的HTTP方法(比如POST, GET),需要写入请求的实体(头部和主体 或 头部 或 主体,也可以是null) ,响应消息的类型,包含uri模板值的map" / "URI格式的url,指定的HTTP方法(比如POST, GET),需要写入请求的实体(头部和主体 或 头部 或 主体,也可以是null) ,响应消息的类型" / "url,指定的HTTP方法(比如POST, GET),需要写入请求的实体(头部和主体 或 头部 或 主体,也可以是null) ,响应消息的类型-ParameterizedTypeReference<T>,扩展模板的变量" / "url,指定的HTTP方法(比如POST, GET),需要写入请求的实体(头部和主体 或 头部 或 主体,也可以是null) ,响应消息的类型-ParameterizedTypeReference<T>,包含uri模板值的map" / "URI格式的url,指定的HTTP方法(比如POST, GET),需要写入请求的实体(头部和主体 或 头部 或 主体,也可以是null) ,响应消息的类型-ParameterizedTypeReference<T>" / "需要写入请求的实体(头部和主体 或 头部 或 主体,不可以是null), 响应消息的类型" / "需要写入请求的实体(头部和主体 或 头部 或 主体,不可以是null), 响应消息的类型-ParameterizedTypeReference<T>"。
2.execute(),在URL上执行特定的HTTP方法,返回一个从相应体映射得到的对象。
该方法可以对指定的URI模板执行请求的HTTP方法,用RequestCallback准备请求,并用ResponseExtractor读取响应,最后返回一个arbitrary对象(这里有个困惑,不知道怎么翻译才准确;根据英文定义,“An arbitrary object has those properties common to the individual objects in its range”即一个对象具有其范围内各个对象所共有性质的属性;物以类聚的感觉)。
官方对该函数的解释如下:

首先是需要5个参数:url,指定的HTTP方法(比如POST, GET),功能性的接口RequestCallback(准备请求的对象;可以是null),从响应消息里提取返回值的对象(可以是null)和扩展模板的变量 以及 最后会返回T。
当然该函数的参数也可以是"url,指定的HTTP方法(比如POST, GET),功能性的接口RequestCallback(准备请求的对象;可以是null),从响应消息里提取返回值的对象(可以是null)和包含uri模板值的map" / "URI格式的url,指定的HTTP方法(比如POST, GET),功能性的接口RequestCallback(准备请求的对象;可以是null),从响应消息里提取返回值的对象(可以是null)"。
【需要注意的地方】
1.url里面要把http/https写上,不然会报错;浏览器地址会帮我们自动补全,这里url变量可不会了
2.解决中文乱码的问题:.setContentType(MediaType.APPLICATION_JSON_UTF8),针对HttpHeaders
3.getForEntity() 返回的是HttpEntity<String>,如果我们需要的是里面的内容,我们需要HttpEntity<String>.getBody()来获取里面的字符串 或则 直接就用getForObject()
4.URL是URI的一个子集。 在《HTTP权威指南》一书中,对于URI的定义是:统一资源标识符;对于URL的定义是:统一资源定位符。 二者的区别在于,URI表示请求服务器的路径,定义这么一个资源。 而URL同时说明要如何访问这个资源(http://)
5.一个arbitrary对象(这里有个困惑,不知道怎么翻译才准确;根据英文定义,“An arbitrary object has those properties common to the individual objects in its range”即一个对象具有其范围内各个对象所共有性质的属性;物以类聚的感觉。)。
【参考资料】
4种Springboot RestTemplate 服务里发送HTTP请求用法的更多相关文章
- HttpClient服务端发送http请求
本来以为对跨域问题的处理已经比较熟练了.可以通过jsonp.document.domain+iframe.window.name.window.postMessage.服务器上设置代理页面来解决.但还 ...
- 服务端发送xml请求java代码示例
/** * */ package com.autoyol.pay.cmb.core; import java.io.ByteArrayOutputStream; import java.io.IOEx ...
- jQuery表单 Ajax向PHP服务端发送文件请求并返回数据
ImageAjaxUpLoad.htm <!DOCTYPE html> <head> <meta charset='utf-8'> <title>< ...
- Query通过Ajax向PHP服务端发送请求并返回JSON数据
Query通过Ajax向PHP服务端发送请求并返回JSON数据 服务端PHP读取MYSQL数据,并转换成JSON数据,传递给前端Javascript,并操作JSON数据.本文将通过实例演示了jQuer ...
- jQuery通过Ajax向PHP服务端发送请求并返回JSON数据
SON(JavaScript Object Notation) 是一种轻量级的数据交换格式.易于人阅读和编写,同时也易于机器解析和生成.JSON在前后台交互的过程中发挥着相当出色的作用.请接着往下看教 ...
- python接口自动化(八)--发送post请求的接口(详解)
简介 上篇介绍完发送get请求的接口,大家必然联想到发送post请求的接口也不会太难,被聪明的你又猜到了.答案是对的,虽然发送post请求的参考例子很简单,但是实际遇到的情况却是很复杂的,因为所有系统 ...
- RestTemplate工具类根据服务名发送请求
要使用RestTemplate 根据服务名发送请求的话需要 使用 @LoadBalanced 这个注解,用了这个注解的RestTemplate就不用使用 ip 来请求了,首先要创建一个配置类 i ...
- 【Java SpringBoot】RestTemplate使用postForObject发送请求,接收String类型的response时中文乱码
https://blog.csdn.net/qq_43758789/article/details/120576717 使用RestTemplate发送PostForObject的时候会出现乱码.这是 ...
- springboot 邮件服务
springboot仍然在狂速发展,才五个多月没有关注,现在看官网已经到1.5.3.RELEASE版本了.准备慢慢在写写springboot相关的文章,本篇文章使用springboot最新版本1.5. ...
- 我眼中的 Nginx(六):深入 Nginx/Openresty 服务里的 DNS 解析
张超:又拍云系统开发高级工程师,负责又拍云 CDN 平台相关组件的更新及维护.Github ID: tokers,活跃于 OpenResty 社区和 Nginx 邮件列表等开源社区,专注于服务端技术的 ...
随机推荐
- Python拆分列中文和 字符
需求描述:我们日常实际的工作中经常需要把一列数据按中文和 数字或者字母单独拆分出来 导入所需的库: import pandas as pd 定义函数 extract_characters,该函数接受三 ...
- golang在win10安装、环境配置 和 goland开发工具golang配置 及Terminal的git配置
前言 本人在使用goland软件开发go时,对于goland软件配置网上资料少,为了方便自己遗忘.也为了希望和我一样的小白能够更好的使用,所以就写下这篇博客,废话不多说开搞. 一.查看自己电脑系统版本 ...
- MacOS X终端里SSH会话管理
http://codelife.me/blog/2012/09/01/ssh-session-profile-management-in-terminal-of-macos-x/ 本文介绍如何在终端里 ...
- OpenGL 摄像机视角详解
1. 摄像机 摄像机就好像是我们的眼睛,我们从摄像机的方向观察世界空间中的模型.摄像机远离模型,模型自然就变小了(透视投影下),然而,在GL中事实上并没有摄像机的概念.但是我们可以通过移动世界空间远离 ...
- 你所不知道的ASP.NET Core进阶系列(三)
前言 一年多没更新博客,上一次写此系列还是四年前,虽迟但到,没有承诺,主打随性,所以不存在断更,催更,哈哈,上一篇我们细究从请求到绑定详细原理,本篇则是探讨模型绑定细节,当一个问题产生到最终解决时,回 ...
- Shell必备三剑客
Top 目录 Sed--三剑客之一 基本格式 选项及含义 命令flags标记及功能 支持正则表达式, 扩展正则表达式 高级命令 命令格式 注意: 命令示例 字符串替换----'s' 行内容替换--'c ...
- Walrus 0.4发布:单一配置、多态运行,体验下一代应用交付模型
今天,我们高兴地宣布云原生统一应用平台 Walrus 0.4 正式发布,这是一个里程碑式的版本更新.新版本采用了全新的应用模型--仅需进行单一配置,即可在多种模态的基础设施及环境中运行包括应用服务及周 ...
- Unity学习笔记--数据持久化XML文件(2)
IXmlSerializable接口: 使用该接口可以帮助处理不能被序列化和反序列化的特殊类得到处理, 使特殊类继承IXmlSerializable接口 ,实现其中的读写方法,检测到读写方法被重写之后 ...
- 前端优化之路:git commit 校验拦截
[前言] 前面在git分支规范那篇文章里,介绍了commit提交规范,如下图 但是想要做到高效落地执行,就需要做些别的功课,先展示下成果图 没错,对不符合规范的commit进行了拦截,符合才可以成功提 ...
- 从0到1,手把手带你开发截图工具ScreenCap------001实现基本的截图功能
ScreenCap---Version:001 说明 从0到1,手把手带你开发windows端的截屏软件ScreenCap 当前版本:ScreenCap---001 支持全屏截图 支持鼠标拖动截图区域 ...