从0开始构建SpringCloud微服务(1)

26次阅读

共计 1699 个字符,预计需要花费 5 分钟才能阅读完成。

照例附上项目 github 链接
本项目实现的是将一个简单的天气预报系统一步一步改造成一个 SpringCloud 微服务系统的过程,第一节将介绍普通天气预报系统的简单实现。

数据来源:
数据来源 1:http://wthrcdn.etouch.cn/weather_mini?city= 深圳
数据来源 2:http://wthrcdn.etouch.cn/weather_mini?citykey=101280601
数据来源 3:http://mobile.weather.com.cn/js/citylist.xml

数据格式

根据返回的数据格式在 vo 包下面创建 pojo。

Service
创建 WeatherDataService 在其中提供如下接口:
1)根据城市 Id 获取城市天气数据的接口。
@Override
public WeatherResponse getDataByCityId(String cityId) {
String url=WEATHER_URI+ “citykey=” + cityId;
return this.doGetWeather(url);
}
2)根据城市名称获取天气数据的接口。
@Override
public WeatherResponse getDataByCityName(String cityName) {
String url = WEATHER_URI + “city=” + cityName;
return this.doGetWeather(url);
}
其中 doGetWeather 方法为抽离出来的请求天气数据的方法。
private WeatherResponse doGetWeahter(String uri) {
ResponseEntity<String> respString = restTemplate.getForEntity(uri, String.class);

ObjectMapper mapper = new ObjectMapper();
WeatherResponse resp = null;
String strBody = null;

if (respString.getStatusCodeValue() == 200) {
strBody = respString.getBody();
}

try {
resp = mapper.readValue(strBody, WeatherResponse.class);
} catch (IOException e) {
e.printStackTrace();
}

return resp;
}

Controller
在 controller 中分别提供根据城市 id 与名称获取天气数据的接口。
@RestController
@RequestMapping(“/weather”)
public class WeatherController {
@Autowired
private WeatherDataService weatherDataService;

@GetMapping(“/cityId/{cityId}”)
public WeatherResponse getWeatherByCityId(@PathVariable(“cityId”) String cityId) {
return weatherDataService.getDataByCityId(cityId);
}

@GetMapping(“/cityName/{cityName}”)
public WeatherResponse getWeatherByCityName(@PathVariable(“cityName”) String cityName) {
return weatherDataService.getDataByCityName(cityName);
}
}

配置
创建 Rest 的配置类。
@Configuration
public class RestConfiguration {

@Autowired
private RestTemplateBuilder builder;

@Bean
public RestTemplate restTemplate() {
return builder.build();
}

}

请求结果:

正文完
 0