springboot 采用HttpClient获取天气预报 异常及原因

采用httpClient调用天气预报地址获取出现异常

2018-10-04 15:18:25.815 ERROR 10868 --- [nio-8080-exec-5] o.a.c.c.C.[.[.[/].[dispatcherServlet]    : Servlet.service() for servlet [dispatcherServlet] in context with path [] threw exception [Request processing failed; nested exception is org.springframework.web.client.HttpServerErrorException: 502 Bad Gateway] with root cause

org.springframework.web.client.HttpServerErrorException: 502 Bad Gateway
    at org.springframework.web.client.DefaultResponseErrorHandler.handleError(DefaultResponseErrorHandler.java:97) ~[spring-web-5.0.9.RELEASE.jar:5.0.9.RELEASE]
    at org.springframework.web.client.DefaultResponseErrorHandler.handleError(DefaultResponseErrorHandler.java:79) ~[spring-web-5.0.9.RELEASE.jar:5.0.9.RELEASE]
    at org.springframework.web.client.ResponseErrorHandler.handleError(ResponseErrorHandler.java:63) ~[spring-web-5.0.9.RELEASE.jar:5.0.9.RE
LEASE]

当前异常产生原因是调用服务器地址我写错了导致的异常

错误代码:

正确的服务地址:

第二个异常json转换异常

 正确获取到一个json格式数据后要将当前json字符串转换成指定类型对象

    private WeatherResponse doGetWeather(String uri){
        //通过spring  restTemplate 客户端发送请求获取 String类型响应实体
        ResponseEntity<String> respString = restTemplate.getForEntity(uri, String.class);

        //Springboot内部集成了json操作对象
        ObjectMapper objectMapper = new ObjectMapper();
        WeatherResponse resp=null;
        String strBody = null;
        //通过响应客户端获取状态码判断是否为成功状态码
        if(respString.getStatusCodeValue()==200){
            //获取响应实体内容实体
            strBody = respString.getBody();
        }
        try {
            //通过json操作对象将string 类型数据转为指定类型对象
            resp = objectMapper.readValue(strBody, WeatherResponse.class);
        } catch (IOException e) {
            e.printStackTrace();
        }
        return resp;
    }
}

由于weatherResponse实体内定义的属性与json 返回属性不一致

public class WeatherResponse implements Serializable{

    private Weather weather;

    private Integer status;

    private String desc;

json数据属性:  返回json 数据属性为data  而实体中属性Weather 为weather 应该修改为Weather  data   

异常信息:这里会清晰的指出属性是哪一个问题

 

posted @ 2018-10-04 15:32  liuwd  阅读(3122)  评论(0编辑  收藏  举报