news 2026/4/16 15:12:42

Entity类转换为VO类

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Entity类转换为VO类

1. 基础实现(手动转换)

package com.itheima.miniblog.vo; import lombok.Data; @Data public class UserVo { private Integer id; private String username; // 脱敏的手机号 private String mobile; private String avatar; // 状态文本 private String statusText; /** * 构造方法:从 User 实体转换 */ public UserVo(Integer id, String username, String mobile, String avatar, Integer status) { this.id = id; this.username = username; this.mobile = maskMobile(mobile); // 脱敏处理 this.avatar = avatar; this.statusText = convertStatusText(status); } /** * 手机号脱敏方法 * 将 13812345678 转换为 138****5678 */ private String maskMobile(String mobile) { if (mobile == null || mobile.length() != 11) { return mobile; } return mobile.substring(0, 3) + "****" + mobile.substring(7); } /** * 状态转换方法 */ private String convertStatusText(Integer status) { if (status == null) return "未知"; switch (status) { case 0: return "禁用"; case 1: return "正常"; case 2: return "锁定"; case 3: return "待激活"; default: return "未知"; } } }

2. 使用 Builder 模式(推荐)

package com.itheima.miniblog.vo; import lombok.AllArgsConstructor; import lombok.Builder; import lombok.Data; import lombok.NoArgsConstructor; @Data @Builder @NoArgsConstructor @AllArgsConstructor public class UserVo { private Integer id; private String username; private String mobile; private String avatar; private String statusText; // 自定义 setter 用于脱敏 public void setMobile(String mobile) { this.mobile = maskMobile(mobile); } public void setStatus(Integer status) { this.statusText = convertStatusText(status); } // 静态工厂方法 public static UserVo fromEntity(com.itheima.miniblog.entity.User user) { return UserVo.builder() .id(user.getId()) .username(user.getUsername()) .mobile(maskMobile(user.getMobile())) .avatar(user.getAvatar()) .statusText(convertStatusText(user.getStatus())) .build(); } private static String maskMobile(String mobile) { if (mobile == null || mobile.length() != 11) { return mobile; } return mobile.substring(0, 3) + "****" + mobile.substring(7); } private static String convertStatusText(Integer status) { if (status == null) return "未知"; return switch (status) { case 0 -> "禁用"; case 1 -> "正常"; case 2 -> "锁定"; case 3 -> "待激活"; default -> "未知"; }; } }

3. 使用枚举优化状态管理

package com.itheima.miniblog.vo; import lombok.AllArgsConstructor; import lombok.Builder; import lombok.Data; import lombok.Getter; @Data @Builder public class UserVo { private Integer id; private String username; private String mobile; private String avatar; private String statusText; // 状态枚举 @Getter @AllArgsConstructor public enum UserStatus { DISABLED(0, "禁用"), NORMAL(1, "正常"), LOCKED(2, "锁定"), PENDING(3, "待激活"); private final Integer code; private final String text; public static String getTextByCode(Integer code) { if (code == null) return "未知"; for (UserStatus status : values()) { if (status.getCode().equals(code)) { return status.getText(); } } return "未知"; } } // 转换方法 public static UserVo fromEntity(com.itheima.miniblog.entity.User user) { String maskedMobile = user.getMobile() != null && user.getMobile().length() == 11 ? user.getMobile().substring(0, 3) + "****" + user.getMobile().substring(7) : user.getMobile(); return UserVo.builder() .id(user.getId()) .username(user.getUsername()) .mobile(maskedMobile) .avatar(user.getAvatar()) .statusText(UserStatus.getTextByCode(user.getStatus())) .build(); } }

4. 使用方法示例

Service 层使用:

@Service public class UserService { public UserVo getUserById(Integer id) { User user = userRepository.findById(id).orElseThrow(); // 方式1:使用构造方法 // return new UserVo(user.getId(), user.getUsername(), // user.getMobile(), user.getAvatar(), user.getStatus()); // 方式2:使用静态工厂方法(推荐) return UserVo.fromEntity(user); } public List<UserVo> getAllUsers() { List<User> users = userRepository.findAll(); // 使用 Stream 转换 return users.stream() .map(UserVo::fromEntity) .collect(Collectors.toList()); } }

Controller 层使用:

@RestController @RequestMapping("/users") public class UserController { @Autowired private UserService userService; @GetMapping("/{id}") public Result<UserVo> getUser(@PathVariable Integer id) { UserVo userVo = userService.getUserById(id); return Result.success(userVo); } @GetMapping public Result<List<UserVo>> getAllUsers() { List<UserVo> userVos = userService.getAllUsers(); return Result.success(userVos); } } // 统一返回结果类 @Data class Result<T> { private Integer code; private String message; private T data; public static <T> Result<T> success(T data) { Result<T> result = new Result<>(); result.setCode(200); result.setMessage("成功"); result.setData(data); return result; } }

5. 使用 MapStruct 自动化转换(高级)

如果项目中有很多 VO 转换,建议使用 MapStruct:

// 1. 添加依赖 // Maven <dependency> <groupId>org.mapstruct</groupId> <artifactId>mapstruct</artifactId> <version>1.5.5.Final</version> </dependency> // 2. 创建转换器接口 @Mapper(componentModel = "spring") public interface UserConverter { UserConverter INSTANCE = Mappers.getMapper(UserConverter.class); @Mapping(target = "mobile", expression = "java(maskMobile(user.getMobile()))") @Mapping(target = "statusText", expression = "java(convertStatusText(user.getStatus()))") UserVo toVo(User user); default String maskMobile(String mobile) { if (mobile == null || mobile.length() != 11) { return mobile; } return mobile.substring(0, 3) + "****" + mobile.substring(7); } default String convertStatusText(Integer status) { // 转换逻辑 return UserVo.UserStatus.getTextByCode(status); } } // 3. 在 Service 中使用 @Service public class UserService { @Autowired private UserConverter userConverter; public UserVo getUserById(Integer id) { User user = userRepository.findById(id).orElseThrow(); return userConverter.toVo(user); } }

总结建议

  1. 基础项目:使用第 2 种方式(Builder 模式 + 静态工厂方法)

  2. 复杂项目:使用第 4 种方式(MapStruct 自动化转换)

  3. 关键点

    • 确保敏感字段不暴露

    • 脱敏处理要完整

    • 状态转换要清晰

    • 提供方便的转换方法

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/16 7:21:01

八股文学习日常(并发编程)

1.介绍Java的内存模型&#xff08;JMM&#xff09;JMM是解决多线程并发问题的一套规则&#xff0c;简单来说就是在多线程环境下&#xff0c;保证线程访问共享变量不出错。核心需要解决的三个问题是可见性&#xff0c;原子性和有序性。可见性问题&#xff1a;线程A对数据进行修改…

作者头像 李华
网站建设 2026/4/15 15:21:42

7、Apache服务器管理与优化全解析

Apache服务器管理与优化全解析 1. 问题排查步骤 当遇到问题时,可按以下步骤进行排查: - 检查每个主机是否有别名。 - 调用 ifconfig -a 命令,查看是否有正确的网络接口。 - 检查 BindAddress 指令是否已定义,并且与别名对应。 2. httpd进程数量管理 服务器进程有…

作者头像 李华
网站建设 2026/4/16 7:22:14

16、Apache服务器的常见配置与使用指南

Apache服务器的常见配置与使用指南 1. 基础配置与操作 在进行Apache相关操作前,需确保指定目录有合适的内容,之后可通过以下命令重启httpd守护进程以读取新配置: apachectl graceful若要完成后续练习,需定位并理解 /usr/local/apache/ 下的Apache配置文件,同时找到Ap…

作者头像 李华
网站建设 2026/4/16 7:24:52

基于STM32单片机快递柜外卖柜扫码取件语音播报蓝牙无线APP/WiFi无线APP/摄像头视频监控/云平台设计S368

STM32-S368-存取柜取件码二维码语音播报存件手机号录入后台数据4舵机OLED屏按键(无线方式选择)产品功能描述&#xff1a;本系统由STM32F103C8T6单片机核心板、OLED屏、&#xff08;无线蓝牙/无线WIFI/无线视频监控/联网云平台模块-可选&#xff09;、键盘部分、语音播报模块接口…

作者头像 李华
网站建设 2026/4/16 7:29:26

Miniconda配置PyTorch避坑指南:版本兼容与DLL加载问题

Miniconda配置PyTorch避坑指南&#xff1a;版本兼容与DLL加载问题 在搭建深度学习开发环境时&#xff0c;你有没有遇到过这样的场景&#xff1f;明明按照官方命令安装了 PyTorch&#xff0c;却在 import torch 时突然报错&#xff1a; ImportError: numpy.ndarray size change…

作者头像 李华
网站建设 2026/4/16 7:27:59

嵌入式模组拨号成功后,与其连接的上位机的网卡获取了IP地址,然后上位机可以通过这个网卡上网,ping百度,做数据业务。如果此时上位机的网卡ping不通百度,需要看什么日志呢?

1、先检查模组是否拨号成功&#xff1f;若拨号成功继续下一步&#xff0c;若拨号失败检查拨号日志。2、检查PDP上下文是否激活&#xff1f;网络注册是否成功&#xff1f;拨号成功不代表数据业务激活比如ATCGACT?检查PDP上下文是否激活比如ATCGREG?检查网络注册状态比如ATCSQ检…

作者头像 李华