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请求内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • SpringBoot中处理跨域资源的5种实现方法与对比

    SpringBoot中处理跨域资源的5种实现方法与对比

    这篇文章主要为大家详细介绍了SpringBoot中处理跨域资源的5种实现方法并进行简单对比,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下
    2026-01-01
  • 使用mybatis的@Interceptor实现拦截sql的方法详解

    使用mybatis的@Interceptor实现拦截sql的方法详解

    拦截器是一种基于 AOP(面向切面编程)的技术,它可以在目标对象的方法执行前后插入自定义的逻辑,本文给大家介绍了使用mybatis的@Interceptor实现拦截sql的方法,需要的朋友可以参考下
    2024-03-03
  • 在 Spring Boot 3 中接入生成式 AI的操作方法

    在 Spring Boot 3 中接入生成式 AI的操作方法

    本文介绍了如何在SpringBoot3中集成生成式AI,以OpenAI的GPT模型为例,通过代码示例展示了如何实现,SpringBoot3的优势和OpenAI的生成式AI技术结合,为开发者提供了高效集成生成式AI的方法,感兴趣的朋友跟随小编一起看看吧
    2025-01-01
  • 浅谈在Java中使用Callable、Future进行并行编程

    浅谈在Java中使用Callable、Future进行并行编程

    这篇文章主要介绍了浅谈在Java中使用Callable、Future进行并行编程,具有一定借鉴价值,需要的朋友可以参考下。
    2017-12-12
  • java-SSH2实现数据库和界面的分页

    java-SSH2实现数据库和界面的分页

    本文主要是介绍SSH2实现数据库和界面的分页的代码,分页在web应用中是经常要做的事情,实用性比较大,有需要的朋友可以来了解一下。
    2016-10-10
  • 解决SpringBoot整合ElasticSearch遇到的连接问题

    解决SpringBoot整合ElasticSearch遇到的连接问题

    这篇文章主要介绍了解决SpringBoot整合ElasticSearch遇到的连接问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2021-08-08
  • Java封装数组之动态数组实现方法详解

    Java封装数组之动态数组实现方法详解

    这篇文章主要介绍了Java封装数组之动态数组实现方法,结合实例形式详细分析了java动态数组的实现原理、操作步骤与相关注意事项,需要的朋友可以参考下
    2020-03-03
  • Mybatis中resultMap标签和sql标签的设置方式

    Mybatis中resultMap标签和sql标签的设置方式

    这篇文章主要介绍了Mybatis中resultMap标签和sql标签的设置方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-01-01
  • 浅谈StringEntity 和 UrlEncodedFormEntity之间的区别

    浅谈StringEntity 和 UrlEncodedFormEntity之间的区别

    这篇文章主要介绍了StringEntity 和 UrlEncodedFormEntity之间的区别,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2021-06-06
  • Java简单工厂和工厂方法模式详细解析

    Java简单工厂和工厂方法模式详细解析

    这篇文章主要介绍了Java简单工厂和工厂方法模式详细解析,简单工厂模式属于类的创新型模式,又叫静态工厂方法模式是通过专门定义一个类来负责创建其他类的实例,被创建的实例通常都具有共同的父类,需要的朋友可以参考下
    2023-12-12

最新评论