栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

Springboot集成restTemplate过程详解

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

Springboot集成restTemplate过程详解

一restTemplate简介

restTemplate底层是基于HttpURLConnection实现的restful风格的接口调用,类似于webservice,rpc远程调用,但其工作模式更加轻量级,方便于rest请求之间的调用,完成数据之间的交互,在springCloud之中也有一席之地。大致调用过程如下图

二restTemplate常用方法列表

forObeject跟forEntity有什么区别呢?主要的区别是forEntity的功能更加强大一些,其返回值是一个ResponseEntity,更加方便我们获得响应的body,head等信息。exchange方法和其他方法不同之处就是能自己定义的rest请求方式。

2.1 get请求方法预览

2.2 post方法请求预览

2.3put请求方法预览

2.4 delete请求方法预览

2.5exchange方法预览

三rest接口调用示例

restTemplate配置

首先本次示例采用的是springboot2.x以上版本,javaSE8;其次发布的服务端是同一台机子,服务端端口8090,客户端端口8080;类路径youku1327;在实际工作中最常用是get,post请求方式;restTemplate简单配置如下:


@Configuration
public class RestTemplateConfig {

  // 配置 RestTemplate
  @Bean
  public RestTemplate restTemplate(ClientHttpRequestFactory factory){
    return new RestTemplate(factory);
  }

  @Bean
  public ClientHttpRequestFactory simpleClientHttpRequestFactory(){
    // 创建一个 httpCilent 简单工厂
    SimpleClientHttpRequestFactory factory = new SimpleClientHttpRequestFactory();
    // 设置连接超时
    factory.setConnectTimeout(15000);
    // 设置读取超时
    factory.setReadTimeout(5000);
    return factory;
  }
}

3.1 get请求接口调用示例

服务费发布的端口

  @GetMapping("user")
  public String getUser(){
    return "youku1327";
  }

  @GetMapping("user/{name}")
  public String getUserName(@PathVariable String name){
    return name;
  }

客户端调用

GET参数说明:

  • 第一个参数是url。
  • 第二个参数是返回值类型。
  • 第三个参数是uri地址路径变量。
 
  @Test
  public void testGETNoParams(){
    String result = restTemplate.getForObject("http://localhost:8090/youku1327/user", String.class);
    System.out.println(result);
  }
  
  @Test
  public void testGETParams(){
    // http://localhost:8090/youku1327/user/{1}
    String result = restTemplate.getForObject("http://localhost:8090/youku1327/user/{name}", String.class,"lsc");
    System.out.println(result);
  }

3.2 post请求示例

POST请求参数说明

第一个参数是url。第二个参数是请求参数。第三个参数是返回值类型。第三个参数是uri地址路径变量。

服务端发布接口

 @PostMapping("provider")
  public ResponseEntity addData(@RequestBody JSonObject jsonObject){
    String user = (String) jsonObject.get("user");
    return ResponseEntity.ok(user);
  }

客户端接口调用

 
  @Test
  public void testPostMethod() throws MalformedURLException {
    JSonObject jsonObject = new JSonObject();
    jsonObject.put("user","youku1327");
    HttpHeaders httpHeaders = new HttpHeaders();
    // 设置请求类型
    httpHeaders.setContentType(MediaType.APPLICATION_JSON_UTF8);
    // 封装参数和头信息
    HttpEntity httpEntity = new HttpEntity(jsonObject,httpHeaders);
    String url = "http://localhost:8090/youku1327/provider";
    ResponseEntity mapResponseEntity = restTemplate.postForEntity(url, httpEntity, String.class);
    System.out.println(mapResponseEntity.getBody());
  }

3.3 put接口调用示例

PUT请求参数说明

第一个参数是url。第二个参数是请求参数。第三个参数是uri地址路径变量。

服务端发布接口

 @PutMapping("provider/{id}")
  public ResponseEntity updateData(@PathVariable Long id, @RequestBody JSonObject jsonObject){
    Object object = jsonObject.get("user");
    jsonObject.put("id",id);
    // {"id":1327,"user":"youku1327"}
    System.out.println(jsonObject);
    return ResponseEntity.ok(jsonObject);
  }

客户端接口调用

  

  @Test
  public void testPutMethod() throws MalformedURLException {
    JSonObject jsonObject = new JSonObject();
    jsonObject.put("user","youku1327");
    HttpHeaders httpHeaders = new HttpHeaders();
    // 设置请求类型
    httpHeaders.setContentType(MediaType.APPLICATION_JSON_UTF8);
    // 封装参数和头信息
    HttpEntity httpEntity = new HttpEntity(jsonObject,httpHeaders);
    String url = "http://localhost:8090/youku1327/provider/{id}";
    restTemplate.put(url, httpEntity, 1327);
  }

3.4delete请求示例

DELETE请求参数说明

第一个参数是url第二个参数uri地址路径变量。

服务端发布接口

  @DeleteMapping("provider/{id}")
  public ResponseEntity delData(@PathVariable Long id){
    String result = "delete"+id+"success";
    // delete1327success
    System.out.println(result);
    return ResponseEntity.ok(result);
  }

客户端调用接口

 
  @Test
  public void testDelete(){
    String url = "http://localhost:8090/youku1327/provider/{id}";
    restTemplate.delete(url,1327);
  }

3.5 exchange

参数说明:

第一个参数是url。第二个参数是请求方式。第三个参数是请求实体。第四个参数是返回值类型。第五个参数是uri地址变量。

服务端发布接口

  @GetMapping("user/{name}")
  public String getUserName(@PathVariable String name){
    return name;
  }

客户端调用接口

  
  @Test
  public void testExchange(){
    String url = "http://localhost:8090/youku1327/user/{name}";
    HttpHeaders httpHeaders = new HttpHeaders();
    httpHeaders.setContentType(MediaType.APPLICATION_FORM_URLENCODED);
    HttpEntity httpEntity = new HttpEntity(httpHeaders);
    ResponseEntity exchange = restTemplate.exchange(url, HttpMethod.GET, httpEntity, String.class, "youku1327");
    System.out.println(exchange.getBody());
  }

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持考高分网。

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/134347.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号