springboot中RestTemplate发送HTTP请求的实现示例

 更新时间:2024年03月07日 14:55:05   作者:JBIB  
RestTemplate是一个 spring-web 提供的执行HTTP请求的同步阻塞式工具类,本文就来介绍一下RestTemplate发送HTTP请求,具有一定的参考价值,感兴趣的可以了解一下

一、前言

之前对发送http请求,使用过okhttp,还有httpclient等,这次就直接使用springboot的RestTemplate了。

二、不同的请求方式

我这里只针对POST请求做说明:
下面针对post请求做三种说明:

1、调用的接口参数用@RequestParam标识

此种在APIfox中传参方式是地址栏传参数,没有请求体。

    /**
     * 发送没有请求体的请求
     * @param url 请求url
     * @param reqParam 地址栏参数
     * @return 想要结果
     */
    public static JSONObject httpPostResult(String url, Map<String, Object> reqParam) {
        String params = getParameter(reqParam);
        if (StringUtils.isBlank(params)) {
            log.error("获取sign失败,sign=null");
            return null;
        }
        HttpEntity<Map<String, String>> httpEntity = new HttpEntity<>(setHeaders());
        //解析请求结果
        String result = new RestTemplate().postForObject(url + params, httpEntity, String.class);
        return JSONObject.parseObject(result);
    }
 
    /**
     * 对地址栏的参数进行拼接
     * @param map 地址栏参数
     * @return 拼接后的结果
     */
    public static String getParameter(Map<String, Object> map) {
        try {
            if (MapUtil.isEmpty(map)) {
                return null;
            }
            String result = "";
            for (String key : map.keySet()) {
                if (Objects.nonNull(map.get(key) )) {
                    if (!"".equals(result)) {
                        result += "&";
                    }
                    result = result + key + "=" + map.get(key);
                }
            }
            return result;
        } catch (Exception e) {
            log.error("map转参出错", e);
        }
        return null;
    }

    /**
     * 设置请求头
     * @return 请求头
     */
   private static HttpHeaders setHeaders() {
        HttpHeaders httpHeaders = new HttpHeaders();
        httpHeaders.add("Accept", MediaType.APPLICATION_JSON.toString());
        httpHeaders.add("Accept-Charset", "UTF-8");
        return httpHeaders;
    }

在Apifox中调用如下:

请求体body=none。

对应的curl命令如下:

curl --location --request POST 'http://xxx:8080/tree/getTree?param1=abc&param2=123&param3=def' \

2、调用的接口参数用@RequestBody标识

此种在APIfox中传参方式是地址栏需要传参数,且有请求体。

    /**
     * 发送带有地址栏参数,有请求体的请求
     * @param url 请求 url
     * @param reqParam url上的参数
     * @param reqBody 请求体
     * @return 响应结果
     */
    public static JSONObject httpPostResult(String url, Map<String, Object> reqParam, Map<String, Object> reqBody) {
        String params = getParameter(reqParam);
        if (StringUtils.isBlank(params)) {
            log.error("获取sign失败,sign=null");
            return null;
        }
        //封装请求头和内容
        HttpEntity<Map<String, Object>> requestEntity = new HttpEntity<>(reqBody, setHeaders());
        //解析请求结果
        String result = new RestTemplate().postForObject(url + params, requestEntity, String.class);
        return JSONObject.parseObject(result);
    }

Apifox上我就只展示body了:

Params和上面的没有请求体的一样。

curl命令如下:

curl --location --request POST 'http://xxx:8080/tree/getTree?param1=abc&param2=123&param3=def' --header 'Content-Type: application/json' \
--data-raw '{"parentId":80}'

这个命令里面的data-raw的值就是请求体。

3、调用的接口参数没有标识

这种的是所有的参数都使用form-data的格式进行传输:

这种就必须使用LinkedMultiValueMap对参数进行封装:

    /**
     * 发送form-data请求
     * @param url 请求 url
     * @param data 请求体
     * @return 响应结果
     */
    public JSONObject httpPostResult(String url, MultiValueMap<String, String> data) {
        HttpHeaders headers = new HttpHeaders();
        headers.setContentType(MediaType.APPLICATION_FORM_URLENCODED);
        //解析请求结果
        HttpEntity<MultiValueMap<String, String>> requestEntity = new HttpEntity<>(data, headers);
        ResponseEntity<String> response = restTemplate.postForEntity(url, requestEntity, String.class);
        return JSONObject.parseObject(response.getBody());
    }

对应的controller中不需要任何注解:

 @PostMapping("/postRequest")
    public JSONObject intervalData(ChargeLogIntervalDataReq request) {
        String url = "http://xxx:8081/api/list";
        MultiValueMap<String, String> data = new LinkedMultiValueMap<>();
        data.put("page", Lists.newArrayList(request.getPage()));
        data.put("limit", Lists.newArrayList(request.getLimit()));
        return httpUtils.httpPostResult(url, data);
    }

这里要注意,MultiValueMap的value得是list才行。

到此这篇关于springboot中RestTemplate发送HTTP请求的实现示例的文章就介绍到这了,更多相关springboot RestTemplate发送HTTP请求内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Spring Boot项目利用Redis实现session管理实例

    Spring Boot项目利用Redis实现session管理实例

    本篇文章主要介绍了Spring Boot项目利用Redis实现session管理实例,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-06-06
  • IntelliJ IDEA 2018 最新激活码(截止到2018年1月30日)

    IntelliJ IDEA 2018 最新激活码(截止到2018年1月30日)

    这篇文章主要介绍了IntelliJ IDEA 2018 最新激活码(截止到2018年1月30日)的相关资料,需要的朋友可以参考下
    2018-01-01
  • 图解JVM垃圾内存回收算法

    图解JVM垃圾内存回收算法

    这篇文章主要介绍了图解JVM垃圾内存回收算法,由于年轻代堆空间的垃圾回收会很频繁,因此其垃圾回收算法会更加重视回收效率,下面小编就和大家来一起学习一下吧
    2019-06-06
  • @Configuration与@Component作为配置类的区别详解

    @Configuration与@Component作为配置类的区别详解

    这篇文章主要介绍了@Configuration与@Component作为配置类的区别详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-06-06
  • spring boot+mybatis 多数据源切换(实例讲解)

    spring boot+mybatis 多数据源切换(实例讲解)

    下面小编就为大家带来一篇spring boot+mybatis 多数据源切换(实例讲解)。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-09-09
  • Java判断上传图片格式的实例代码

    Java判断上传图片格式的实例代码

    这篇文章主要介绍了Java判断上传图片格式的实例代码,在文中给大家提到了Java使用文件头的类型判断上传的文件是否为图片类型,需要的朋友可以参考下
    2019-06-06
  • MyBatis逆向工程生成dao层增删改查的操作

    MyBatis逆向工程生成dao层增删改查的操作

    这篇文章主要介绍了MyBatis逆向工程生成dao层增删改查的操作,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2021-08-08
  • MyBatis中useGenerateKeys的使用解析

    MyBatis中useGenerateKeys的使用解析

    这篇文章主要介绍了MyBatis中useGenerateKeys的使用,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2021-09-09
  • 利用Java异常机制实现模拟借书系统

    利用Java异常机制实现模拟借书系统

    这篇文章主要给大家介绍了利用Java异常机制实现模拟借书系统的相关资料,文中先对java异常机制进行了简单介绍,而后通过示例代码介绍了java语言是如何实现一个控制台版的模拟借书系统,需要的朋友可以参考学习,一起来看看吧。
    2017-04-04
  • java虚拟机原理:Class字节码二进制文件分析

    java虚拟机原理:Class字节码二进制文件分析

    class文件全名称为Java class文件,主要在平台无关性和网络移动性方面使Java更适合网络。它在平台无关性方面的任务是:为Java程序提供独立于底层主机平台的二进制形式的服务。下面我们来详细解读下它吧
    2021-09-09

最新评论