返回实体类对象的部分属性给前端的三种方法

分两种类型:

1.要返回的属性是实体类的部分属性,不含额外的属性
2.要返回的属性是实体类的部分属性,又含额外的属性

方法1:对于类型1:使用@JsonIgnore注解。

如果使用的是JSON作为数据交换格式,可以在实体类上使用注解来控制序列化行为。

对于Jackson库,可以使用@JsonIgnore注解来忽略不需要的属性:

java 复制代码
import com.fasterxml.jackson.annotation.JsonIgnore;

public class MyEntity {
    private String visibleField;
    @JsonIgnore
    private String hiddenField;
    // getters and setters
}

方法二:对于类型1和2:创建一个DTO(Data Transfer Object)类,DTO是专门设计用于数据传输的类。

java 复制代码
public class MyEntity {
    private String field1;
    private String field2;
    private String field3;
    // getters and setters
}

public class MyEntityDTO {
    private String field1;
    private String field2;
    private String field4;//额外的属性
    // Only getters and setters for fields you want to expose
}

// 在业务逻辑或服务层中
MyEntity entity = // ... get from database
MyEntityDTO dto = new MyEntityDTO();
dto.setField1(entity.getField1());
dto.setField2(entity.getField2());
dto.setField4("额外的属性");
// Return dto to the frontend

方法三:对于类型1和2:使用Map

java 复制代码
Map<String, Object> response = new HashMap<>();
response.put("field1", entity.getField1());
response.put("field2", entity.getField2());
response.put("field4", "额外的属性");
// Do not include "field3"
return response;
相关推荐
WizLC1 分钟前
【JAVA】JVM类加载器知识笔记
java·jvm·笔记
喝汽水的猫^3 分钟前
Java实现Excel 导出(多 Sheet、复杂格式)
java·excel
毕设源码-朱学姐15 分钟前
【开题答辩全过程】以 基于JavaWeb的疾病查询系统的设计与实现为例,包含答辩的问题和答案
java·eclipse
雨中飘荡的记忆17 分钟前
Java面向对象编程详解
java·开发语言
zhangyifang_00926 分钟前
Spring中的BeanFactory类
java·后端·spring
大学生资源网29 分钟前
java毕业设计之面向校园的助力跑腿系统设计与实现源码(源码+文档+数据库)
java·数据库·mysql·毕业设计·源码·springboot
quikai19811 小时前
python练习第六组
java·前端·python
222you1 小时前
线程的常用方法
java·开发语言
是梦终空1 小时前
JAVA毕业设计259—基于Java+Springboot+vue3工单管理系统的设计与实现(源代码+数据库+开题报告)
java·spring boot·vue·毕业设计·课程设计·工单管理系统·源代码
用户2190326527351 小时前
Spring Boot 集成 Redis 实现看门狗 Lua 脚本分布式锁
java·后端