国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁技術文章
文章詳情頁

Springboot集成restTemplate過程詳解

瀏覽:67日期:2023-05-22 10:38:42

一restTemplate簡介

restTemplate底層是基于HttpURLConnection實現的restful風格的接口調用,類似于webservice,rpc遠程調用,但其工作模式更加輕量級,方便于rest請求之間的調用,完成數據之間的交互,在springCloud之中也有一席之地。大致調用過程如下圖

Springboot集成restTemplate過程詳解

二restTemplate常用方法列表

forObeject跟forEntity有什么區別呢?主要的區別是forEntity的功能更加強大一些,其返回值是一個ResponseEntity,更加方便我們獲得響應的body,head等信息。exchange方法和其他方法不同之處就是能自己定義的rest請求方式。

2.1 get請求方法預覽

Springboot集成restTemplate過程詳解

2.2 post方法請求預覽

Springboot集成restTemplate過程詳解

2.3put請求方法預覽

Springboot集成restTemplate過程詳解

2.4 delete請求方法預覽

Springboot集成restTemplate過程詳解

2.5exchange方法預覽

Springboot集成restTemplate過程詳解

三rest接口調用示例

restTemplate配置

首先本次示例采用的是springboot2.x以上版本,javaSE8;其次發布的服務端是同一臺機子,服務端端口8090,客戶端端口8080;類路徑youku1327;在實際工作中最常用是get,post請求方式;restTemplate簡單配置如下:

/** * @Author lsc * @Description <p> </p> * @Date 2019/10/14 11:40 * @Version 1.0 */@Configurationpublic 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地址路徑變量。

/* * @Author lsc * @Description <p> 獲得無參的get請求 </p> * @Date 2019/10/17 21:15 * @Param [] * @return void **/ @Test public void testGETNoParams(){ String result = restTemplate.getForObject('http://localhost:8090/youku1327/user', String.class); System.out.println(result); } /* * @Author lsc * @Description <p> URL帶參 </p> * @Date 2019/10/18 13:49 * @Param [] * @return void **/ @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<String> addData(@RequestBody JSONObject jsonObject){ String user = (String) jsonObject.get('user'); return ResponseEntity.ok(user); }

客戶端接口調用

/* * @Author lsc * @Description <p> post</p> * @Date 2019/10/18 23:23 * @Param [] * @return void **/ @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<JSONObject> httpEntity = new HttpEntity(jsonObject,httpHeaders); String url = 'http://localhost:8090/youku1327/provider'; ResponseEntity<String> mapResponseEntity = restTemplate.postForEntity(url, httpEntity, String.class); System.out.println(mapResponseEntity.getBody()); }

3.3 put接口調用示例

PUT請求參數說明

第一個參數是url。第二個參數是請求參數。第三個參數是uri地址路徑變量。

服務端發布接口

@PutMapping('provider/{id}') public ResponseEntity<JSONObject> 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); }

客戶端接口調用

/* * @Author lsc * @Description <p> put</p> * @Date 2019/10/18 23:23 * @Param * @return **/ @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<JSONObject> 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<String> delData(@PathVariable Long id){ String result = 'delete'+id+'success'; // delete1327success System.out.println(result); return ResponseEntity.ok(result); }

客戶端調用接口

/* * @Author lsc * @Description <p> delete</p> * @Date 2019/10/18 23:22 * @Param [] * @return void **/ @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; }

客戶端調用接口

/* * @Author lsc * @Description <p> exchange</p> * @Date 2019/10/18 23:22 * @Param [] * @return void **/ @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<String> exchange = restTemplate.exchange(url, HttpMethod.GET, httpEntity, String.class, 'youku1327'); System.out.println(exchange.getBody()); }

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持好吧啦網。

標簽: Spring
相關文章:
主站蜘蛛池模板: 亚洲高清国产一线久久 | 国产永久高清免费动作片www | 在线国产一区 | 久久精品一区二区国产 | 亚洲深夜 | 成人做爰网站免费看 | 色精品一区二区三区 | 性夜影院爽黄a爽免费看网站 | 美女黄色在线网站大全 | a毛片毛费观看 | 99久久精品国产片 | 精品视频一区二区三三区四区 | 国产一级淫片a免费播放口之 | 欧美另类视频videosbest18 | 国产午夜亚洲精品国产 | 国产成人免费片在线视频观看 | 美女国产福利视频 | 中文字幕在线播 | 亚洲精品中文字幕久久久久久 | 在线はじめてのおるすばん | 亚洲国产成人久久综合一区 | 大陆老太xxxxxxxxhd | 欧美a级毛片| 国产欧美日韩在线视频 | 中文字幕有码在线视频 | 亚洲精品国产拍拍拍拍拍 | 成 人 黄 色 视频播放16 | 亚洲国产精品自在现线让你爽 | 国产精品久久免费观看 | 日本一级级特黄特色大片 | 国产精品国产 | 久久高清一区二区三区 | 三级毛片免费 | 精品国产精品久久一区免费式 | 国产成人午夜性a一级毛片 国产成人午夜性视频影院 国产成人香蕉久久久久 | 亚洲资源在线 | 98国内自拍在线视频 | 欧美大片aaa | 欧美人性影片免费看 | 99久久精品久久久久久婷婷 | 精品在线免费视频 |