詳解SpringBoot通過restTemplate實現(xiàn)消費服務(wù)
一、RestTemplate說明
RestTemplate是Spring提供的用于訪問Rest服務(wù)的客戶端,RestTemplate提供了多種便捷訪問遠程Http服務(wù)的方法,能夠大大提高客戶端的編寫效率。前面的博客中//www.dbjr.com.cn/article/132885.htm,已經(jīng)使用Jersey客戶端來實現(xiàn)了消費spring boot的Restful服務(wù),接下來,我們使用RestTemplate來消費前面示例中的Restful服務(wù),前面的示例:
springboot整合H2內(nèi)存數(shù)據(jù)庫,實現(xiàn)單元測試與數(shù)據(jù)庫無關(guān)性
該示例提供的Restful服務(wù)如下:http://localhost:7900/user/1
{"id":1,"username":"user1","name":"張三","age":20,"balance":100.00}
二、創(chuàng)建工程

三、工程結(jié)構(gòu)

pom文件依賴如下:
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>com.chhliu.springboot.restful</groupId>
<artifactId>springboot-rest-template</artifactId>
<version>0.0.1-SNAPSHOT</version>
<packaging>jar</packaging>
<name>springboot-rest-template</name>
<description>Demo project for Spring Boot RestTemplate</description>
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>1.4.3.RELEASE</version>
<relativePath/> <!-- lookup parent from repository -->
</parent>
<properties>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
<project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
<java.version>1.7</java.version>
</properties>
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency>
<!-- 熱啟動,熱部署依賴包,為了調(diào)試方便,加入此包 -->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-devtools</artifactId>
<optional>true</optional>
</dependency>
</dependencies>
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
</plugins>
</build>
</project>
四、加入vo
由于我們使用RestTemplate調(diào)用Restful服務(wù)后,需要將對應(yīng)的json串轉(zhuǎn)換成User對象,所以需要將這個類拷貝到該工程中,如下:
package com.chhliu.springboot.restful.vo;
import java.math.BigDecimal;
public class User {
private Long id;
private String username;
private String name;
private Short age;
private BigDecimal balance;
// ……省略getter和setter方法
/**
* attention:
* Details:TODO
* @author chhliu
* 創(chuàng)建時間:2017-1-20 下午2:05:45
* @return
*/
@Override
public String toString() {
return "User [id=" + id + ", username=" + username + ", name=" + name
+ ", age=" + age + ", balance=" + balance + "]";
}
}
五,編寫controller
package com.chhliu.springboot.restful.controller;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.RestController;
import org.springframework.web.client.RestTemplate;
import com.chhliu.springboot.restful.vo.User;
@RestController
public class RestTemplateController {
@Autowired
private RestTemplate restTemplate;
@GetMapping("/template/{id}")
public User findById(@PathVariable Long id) {
// http://localhost:7900/user/是前面服務(wù)的對應(yīng)的url
User u = this.restTemplate.getForObject("http://localhost:7900/user/" + id,
User.class);
System.out.println(u);
return u;
}
}
六、啟動程序
package com.chhliu.springboot.restful;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.boot.web.client.RestTemplateBuilder;
import org.springframework.context.annotation.Bean;
import org.springframework.web.client.RestTemplate;
@SpringBootApplication
public class SpringbootRestTemplateApplication {
// 啟動的時候要注意,由于我們在controller中注入了RestTemplate,所以啟動的時候需要實例化該類的一個實例
@Autowired
private RestTemplateBuilder builder;
// 使用RestTemplateBuilder來實例化RestTemplate對象,spring默認已經(jīng)注入了RestTemplateBuilder實例
@Bean
public RestTemplate restTemplate() {
return builder.build();
}
public static void main(String[] args) {
SpringApplication.run(SpringbootRestTemplateApplication.class, args);
}
}
七、測試
在瀏覽器中輸入:http://localhost:7902/template/1
測試結(jié)果如下:
控制臺打印結(jié)果:
User [id=1, username=user1, name=張三, age=20, balance=100.00]
通過上面的測試,說明我們已經(jīng)成功的調(diào)用了spring boot的Restful服務(wù)。
八、改進
上面的測試中,有一個很不好的地方,
User u = this.restTemplate.getForObject("http://localhost:7900/user/" + id,
User.class); 此處出現(xiàn)了硬編碼,當服務(wù)器地址改變的時候,需要改動對應(yīng)的代碼,改進的方法,將Restful服務(wù)的地址寫到配置文件中。
修改controller如下:
package com.chhliu.springboot.restful.controller;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.RestController;
import org.springframework.web.client.RestTemplate;
import com.chhliu.springboot.restful.vo.User;
@RestController
public class RestTemplateController {
@Autowired
private RestTemplate restTemplate;
// Restful服務(wù)對應(yīng)的url地址
@Value("${user.userServicePath}")
private String userServicePath;
@GetMapping("/template/{id}")
public User findById(@PathVariable Long id) {
User u = this.restTemplate.getForObject(this.userServicePath + id, User.class);
System.out.println(u);
return u;
}
}
配置文件修改如下:
server.port:7902 user.userServicePath=http://localhost:7900/user/
啟動程序:
發(fā)現(xiàn)測試是ok的,后面我們會引入spring cloud對這種調(diào)用方式進行進一步的改進!
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
JAVA 開發(fā)之用靜態(tài)方法返回類名的實例詳解
這篇文章主要介紹了JAVA 開發(fā)之用靜態(tài)方法返回類名的實例詳解的相關(guān)資料,這里主要說明使用異常來得到類名,希望能幫助到大家,需要的朋友可以參考下2017-08-08

