**口诀 :“上来 Form,下去 VO,中间 DTO,持久 Entity,别混在一起就舒服。”**
其中最容易混淆的就是 DTO(Data Transfer Object)和 VO(View Object,也常叫 VO/ViewModel)。
>[info]一句话先给出结论:
DTO 面向“服务间、进程间”的数据搬运;VO 面向“前端页面/接口渲染”的数据呈现。 二者诞生的目的、进化方向、字段取舍、变更频度都不一样,因此不要混用。
下面把 Java(及 Spring 全家桶)项目里**最常见的“数据对象”**按**出现层级、主要用途、命名惯例**一张表列清,方便你“对号入座”。
(从上到下 ≈ 用户请求 → 持久化 → 响应用户)
| 名称 | 出现位置 | 典型后缀 | 核心职责 | 常见误区 |
|---|---|---|---|---|
| VO / ViewObject | 控制层 → 前端 | XxxVO / XxxPageVO | 只装“当前页面/接口”需要展示的数据,字段随 UI 变,可脱敏、可合并、可裁剪。 | 当成 DTO 直接远程调用,导致大字段泄露。 |
| DTO | 服务层 ↔ 服务层(含开放 API) | XxxDTO / XxxReqDTO / XxxRespDTO | 跨进程、跨服务一次性搬运数据,字段“多而全”,兼顾序列化性能与版本兼容。 | 把数据库实体直接当 DTO 返回,造成胖接口。 |
| Form / Param | 控制层入参 | XxxForm / XxxQuery | 接收前端表单、查询参数,只做“入参校验”,字段与前端请求一一对应。 | 与 DTO 混用,导致校验注解到处飞。 |
| Entity / PO | DAO 层 | XxxEntity / XxxPO | 与数据库表字段 1:1 映射,生命周期随事务,绝不往外传。 | 直接序列化给前端,暴露表结构甚至密码盐。 |
| BO / BusinessObj | 领域内(可选) | XxxBO | 聚合多表、多服务后的“充血”业务对象,含行为,用于复杂领域逻辑。 | 项目没做 DDD 也硬上 BO,最后变成万能贫血对象。 |
| DO / DataObj | 老派叫法,等价 Entity | —— | 同 Entity,新项目建议统一叫 Entity 或 PO。 | 容易与 BO、DTO 缩写混淆。 |
| AO / AppObj | 非常小众,阿里部分老规范 | XxxAO | 一次“应用服务”维度组装的值对象,介于 BO 与 DTO 之间,普通项目可忽略。 | 没团队规范就别自创,维护者看不懂。 |
| Query / Criteria | DAO 层入参 | XxxQuery / XxxCriteria | 专装动态 SQL 查询条件,字段只放分页、筛选、排序,解耦 Mapper 入参。 | 把 Entity 当查询条件,导致空值字段也拼进 SQL。 |
| POJO | 通称 | —— | 以上所有本质都是 POJO,只是按“职责”再细分。 | 在文档里写“用 POJO 接收”等于没说。 |
一张图速记(请求流向)
```
前端 HTTP 请求
↓ JSON
Controller ← XxxForm / XxxQuery(校验入参)
↓ 转换
Service ← XxxDTO(远程或本地服务间)
↓ 转换
DAO ← XxxEntity / PO(DB 映射)
↓ SQL
数据库
```
返回路径
```
数据库
↓
DAO → XxxEntity
↓ 组装
Service → XxxDTO / XxxBO
↓ 裁剪/脱敏
Controller → XxxVO / XxxPageVO
↓ JSON
前端
```
- 环境配置
- window怎么配置java环境变量?
- SQL学习
- 字段类型
- 1、 所有可声明的字段类型
- 2、常用的可声明的字段类型
- 创建表和表内字段
- 1、整个创建表语句
- 2、设置id主键
- 3、设置业务主键,唯一索引
- 4、设置业务字段
- 5、普通索引
- 6、唯一索引与普通索引的区别
- 7、表的引擎、字符集、排序规则和注释的设置
- Java基础语法
- 数据类型
- Java中的数据类型
- LocalDate
- 常用的数据类型
- Java 常用数据类型方法
- Java中数组、list、Map、HashMap
- 如何用Map来优化那些复杂的“双重 for 循环”查询?
- Java 8 中steam()操作流
- Java中HashMap和JSON
- Java中的JSONObject
- 工具类
- Java 常用工具类
- Arrays工具类
- Java 时间工具类
- 泛型
- Java中泛型概念
- Java中的泛型容器
- 泛型参数与函数参数的区别
- 推断出泛型实参
- Lambda表达式
- 数据分层
- 异常处理
- Java8 异常处理类总结表
- MyBatis-Plus 常用异常类总结表
- Java高级特性
- Maven
- jib-maven-plugin
- 什么是Spring Boot 的 parent pom?
- maven中各个生命周期的含义
- Spring Boot
- maven与spring boot 的关系
- Java中的连接池
- Spring JDBC
- Spring JDBC的概念
- JdbcTemplate常用的方法
- Spring中Bean的概念
- Spring中的抽象,通俗解释一下
- Spring中的事物
- Spring中的事物,通俗解释一下
- Spring中的事物抽象,常见的有哪些,列举一下
- Spring中常用的事物场景有哪些,列举一下
- Spring事务管理有哪些注解?
- Spring中使用事物处理订单的案例,列举说明一下
- Spring中声明式事务、分布式事务以及编程式事务的区别,列举一下
- 配置文件
- application-properties配置文件
- Spring Boot 的启动
- spring boot项目如何启动?
- 列举一下Spring Boot的启动过程
- SpringApplication.run方法
- Spring Boot 启动时有哪些接口?
- CommandLineRunner
- Spring Boot 的常用注解
- 系统注解
- 表格:系统注解
- @Override
- @Deprecated
- @SuppressWarnnings
- 使用在类名上的注解
- 表格:使用在类名上的注解
- @RestController
- @Controller
- @Service
- @Repository
- @Component
- @Configuration
- @Resource
- @Autowired
- @RequestMapping
- @GetMapping
- @PostMapping
- @Transactional
- @Qualifier
- 使用在方法上的注解
- 表格:使用在方法上的注解
- @RequestBody
- @PathVariable
- @Bean
- @ResponseBody
- @PreAuthorize
- 其他常用注解
- 表格:其他常用注解
- @EnableAutoConfiguration
- @SpringBootApplication
- @EnableScheduling
- @EnableAsync
- @ComponentScan
- @Aspec
- @ControllerAdvice
- @ExceptionHandler
- @Value
- @ConfigurationProperties
- @EnableConfigurationProperties
- @MapperScan
- @ApiOperation
- @Produces
- Validator验证的常用注解
- spring IoC容器
- Spring IoC容器依赖注入实现方式
- 常用依赖
- RESTEasy
- resteasy简介
- RESTEasy框架(依赖)的功能和常用注解
- MyBatis
- 简介
- paginationInterceptor
- @TableName
- @TableId
- @Param
- MyBatis-Plus
- MyBatis-Plus简介
- MyBatis-Plus的工具类
- Mybatis-Plus扩展的工具类和方法
- MyBatis-Plus中最常用的工具类方法
- MyBatis-Plus 中最常用的 4 大核心工具类
- Wrapper条件构造器
- Wrapper条件构造器详解
- Wrapper条件构造器eq等方法的参数说明
- LambdaQueryWrapper与QueryWrapper
- 日期格式是否必须转换
- Lombok
- Lombok作用详解
- @Data
- @Slf4j
- @Builder
- @EqualsAndHashCode
- @Accessors
- Jackson
- Jackson简介
- @JsonFormat
- Jackson高效地在 HashMap 和 JSON 字符串之间进行相互转换
- Hutool
- Hutool简介
- hutool依赖常用的方法
- fastjson2
- fastjson2简介
- UrlBasedCorsConfigurationSource
- 生态相关
- JBoss 社区
- 支付系统
- 1. 初始化mysql数据库流程
- 2. 初始化redis数据库的流程
- 3. 初始化rabbitmq服务
- 环球置业
- 1.模块目录结构分析
- 2. DTO(数据传输层)的核心作用
- 3. VO(视图对象层)
- 4. VO(视图对象层)和 DTO 数据传输层 的区别
