RestTemplate 返回实体类型

本文介绍如何使用 RestTemplate 返回自定义实体类而非默认的 LinkedHashMap。通过 ParameterizedTypeReference 设置返回类型,并提供了一个完整的示例代码,展示了如何实现这一过程。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

RestTemplate 返回实体默认情况是LinkedHashMap,想要返回实体类需要如下设置:

ParameterizedTypeReference<ResultObject<Operation>> typeRef = new ParameterizedTypeReference<ResultObject<Operation>>() {};
ResponseEntity<ResultObject<Operation>> responseEntity = loadBalanced.exchange(http://127.0.0.1:9103/operation/user,
HttpMethod.POST, null, typeRef);
ResultObject result= responseEntity.getBody();
return result;
/*辅助类如下*/
public class ResultObject<T> implements Serializable {
    private static final long serialVersionUID = -7339247993272106349L;
    /**
     * 1 统一表示成功
     * 其它数值根据自己的业务逻辑枚举
     */
    @JsonProperty("result")
    private long result;
    @JsonProperty("desc")
    private String desc;
    private T body;
    public ResultObject() {
    }
    public ResultObject(long result) {
        this.setResult(result);
    }
    public ResultObject(long result, String desc) {
        this.result = result;
        this.desc = desc;
    }
    public ResultObject(long result, String desc, T body) {
        this.result = result;
        this.desc = desc;
        this.body = body;
    }
    public long getResult() {
        return result;
    }
    public String getDesc() {
        return desc;
    }
    public void setDesc(String desc) {
        this.desc = desc;
    }
    public T getBody() {
        return body;
    }
    public void setBody(T body) {
        this.body = body;
    }
}
@RequestMapping(value = "/user")
 @ResponseBody
 public  ResultObject<Operation> user(HttpServletRequest request, Model model) {
  ResultObject<Operation> result=new ResultObject<Operation>();
  Operation user = new Operation();
  user.setName("test");
  user.setId(1000l);
  result.setBody(user);
  result.setResult(1);
  result.setDesc("成功");
  return result;
 }


### 如何使用 RestTemplate 返回 List 类型的数据 RestTemplate 是 Spring 提供的一个用于同步 HTTP 请求的类,支持多种 HTTP 方法(如 GET、POST、PUT 等)。当需要从服务器获取一个 `List` 类型的数据时,可以通过 `exchange` 方法结合泛型参数来实现。 以下是实现的具体方式: ```java import org.springframework.http.HttpEntity; import org.springframework.http.HttpHeaders; import org.springframework.http.HttpMethod; import org.springframework.http.MediaType; import org.springframework.web.client.RestTemplate; import java.util.List; public class RestTemplateListExample { public static void main(String[] args) { // 创建 RestTemplate 实例 RestTemplate restTemplate = new RestTemplate(); // 设置请求头 HttpHeaders headers = new HttpHeaders(); headers.setContentType(MediaType.APPLICATION_JSON); // 构建请求实体 HttpEntity<String> entity = new HttpEntity<>(headers); // 定义 URL String url = "http://example.com/api/users"; // 假设返回的是用户列表 // 使用 exchange 方法获取 List 类型数据 List<User> users = restTemplate.exchange( url, HttpMethod.GET, entity, new ParameterizedTypeReference<List<User>>() {} // 指定返回类型为 List<User> ).getBody(); // 输出结果 System.out.println(users); } // 示例 User 类 static class User { private String id; private String name; // Getters and Setters public String getId() { return id; } public void setId(String id) { this.id = id; } public String getName() { return name; } public void setName(String name) { this.name = name; } @Override public String toString() { return "User{id='" + id + "', name='" + name + "'}"; } } } ``` 上述代码中,通过 `ParameterizedTypeReference` 指定了返回类型为 `List<User>`,从而能够正确解析 JSON 数据并将其映射为 Java 对象列表。这种方式适用于返回复杂类型的场景[^2]。 如果服务器返回的是纯 JSON 数组而非包装对象,则可以直接指定返回类型为 `List<Map<String, Object>>` 或其他适合的泛型类型。 ```java List<Map<String, Object>> response = restTemplate.exchange( url, HttpMethod.GET, entity, new ParameterizedTypeReference<List<Map<String, Object>>>() {} ).getBody(); ``` 这种实现方式更加灵活,适用于无法预定义具体对象结构的场景[^3]。 ### 注意事项 1. 如果服务器返回的 JSON 数据格式不符合预期(例如缺少字段或字段类型不匹配),可能会导致反序列化失败。 2. 需要确保服务器返回的 JSON 数据是一个数组,否则会抛出异常。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值