news 2026/6/12 10:29:24

SpringBoot中的命名与开发规范

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
SpringBoot中的命名与开发规范

SpringBoot中的命名与开发规范

在 Spring Boot 项目开发中,Java 类的命名(如BOPOVODTO)通常是根据其在项目中的角色和职责来确定的。平时开发项目,经常对于这些类名的命名有疑惑,所以记录下来。这些命名约定有助于提高代码的可读性和可维护性。以下是每种类型的定义、使用场景和命名建议:


1. PO (Persistent Object)

定义

  • PO 是持久化对象,通常与数据库表一一对应,用于表示数据库中的一条记录。

使用场景

  • 用于与数据库交互的实体类。
  • 通常与 ORM 框架(如 JPA、MyBatis)一起使用。

命名建议

  • 类名通常与数据库表名对应,例如:
@Entity @Table(name = "user") public class UserPO { @Id @GeneratedValue(strategy = GenerationType.IDENTITY) private Long id; private String name; private String email; // Getters and Setters }

2. DTO (Data Transfer Object)

定义

  • DTO 是数据传输对象,用于在不同层(如 Controller 层和 Service 层)之间传递数据。
  • DTO 通常只包含数据字段,不包含业务逻辑。

使用场景

  • 用于封装 API 请求或响应的数据。
  • 用于减少网络传输的数据量(例如,只传递需要的字段)。

命名建议

  • 类名通常以DTO结尾,例如:
public class UserDTO { private Long id; private String name; private String email; // Getters and Setters }

3. VO (Value Object)

定义

  • VO 是值对象,用于表示一个不可变的对象,通常用于封装一组相关的数据。
  • VO 通常是不可变的(即字段为final),并且没有业务逻辑。

使用场景

  • 用于表示一个复杂的值,例如日期范围、坐标等。
  • 用于封装一组相关的数据,便于传递和使用。

命名建议

  • 类名通常以VO结尾,例如:
public class AddressVO { private final String city; private final String street; private final String zipCode; public AddressVO(String city, String street, String zipCode) { this.city = city; this.street = street; this.zipCode = zipCode; } // Getters }

4. BO (Business Object)

定义

  • BO 是业务对象,用于封装业务逻辑和数据。
  • BO 通常包含业务方法和数据字段。

使用场景

  • 用于封装复杂的业务逻辑。
  • 用于表示一个业务实体,例如订单、用户等。

命名建议

  • 类名通常以BO结尾,例如:
public class OrderBO { private Long id; private List<OrderItem> items; private BigDecimal totalAmount; public BigDecimal calculateTotalAmount() { // Business logic to calculate total amount return items.stream() .map(OrderItem::getAmount) .reduce(BigDecimal.ZERO, BigDecimal::add); } // Getters and Setters }

5. 其他常见对象

(1) Entity

  • 与 PO 类似,但更强调与数据库的映射关系。
  • 通常用于 JPA 实体类。

(2) Model

  • 用于表示一个通用的数据模型,通常用于 MVC 模式中的 Model 层。

(3) Form

  • 用于封装表单数据,通常用于前端提交的数据。

6. 如何确定使用哪种对象?

(1) 根据职责划分

  • PO:与数据库表对应,用于持久化数据。
  • DTO:用于层与层之间的数据传输。
  • VO:用于表示一个不可变的值对象。
  • BO:用于封装业务逻辑和数据。

(2) 根据使用场景

  • 如果对象需要与数据库交互,使用PO
  • 如果对象用于 API 请求或响应,使用DTO
  • 如果对象表示一个复杂的值,使用VO
  • 如果对象包含业务逻辑,使用BO

(3) 根据项目规范

  • 遵循团队或项目的命名规范。
  • 保持一致性,避免混用不同类型的对象。

7. 示例:完整的分层结构

以下是一个典型的分层结构示例:

Controller 层

@RestController @RequestMapping("/users") public class UserController { @Autowired private UserService userService; @PostMapping public ResponseEntity<UserDTO> createUser(@RequestBody UserDTO userDTO) { UserDTO createdUser = userService.createUser(userDTO); return ResponseEntity.ok(createdUser); } }

Service 层

@Service public class UserService { @Autowired private UserRepository userRepository; public UserDTO createUser(UserDTO userDTO) { UserPO userPO = convertToPO(userDTO); userRepository.save(userPO); return convertToDTO(userPO); } private UserPO convertToPO(UserDTO userDTO) { // Conversion logic } private UserDTO convertToDTO(UserPO userPO) { // Conversion logic } }

Repository 层

@Repository public interface UserRepository extends JpaRepository<UserPO, Long> { }

PO 类

@Entity @Table(name = "user") public class UserPO { @Id @GeneratedValue(strategy = GenerationType.IDENTITY) private Long id; private String name; private String email; // Getters and Setters }

DTO 类

public class UserDTO { private Long id; private String name; private String email; // Getters and Setters }

总结

  • PO:与数据库表对应,用于持久化数据。
  • DTO:用于层与层之间的数据传输。
  • VO:用于表示一个不可变的值对象。
  • BO:用于封装业务逻辑和数据。
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/10 16:13:08

基于 S7-200 PLC 和组态王的切片机控制系统实现

基于S7-200 PLC和组态王组态切片机控制系统 带解释的梯形图程序&#xff0c;接线图原理图图纸&#xff0c;io分配&#xff0c;组态画面在工业自动化领域&#xff0c;切片机控制系统对于生产效率和产品质量起着至关重要的作用。本文将介绍如何基于 S7 - 200 PLC 和组态王来构建一…

作者头像 李华
网站建设 2026/6/8 13:18:38

Cropper.js图像裁剪库:前端开发者的终极解决方案

Cropper.js图像裁剪库&#xff1a;前端开发者的终极解决方案 【免费下载链接】cropperjs JavaScript image cropper. 项目地址: https://gitcode.com/gh_mirrors/cr/cropperjs 在当今视觉内容主导的数字时代&#xff0c;图像处理已成为Web开发不可或缺的一部分。无论是社…

作者头像 李华
网站建设 2026/6/12 5:23:56

5分钟快速上手:Parse Dashboard完整部署与配置指南

5分钟快速上手&#xff1a;Parse Dashboard完整部署与配置指南 【免费下载链接】parse-dashboard A dashboard for managing Parse Server 项目地址: https://gitcode.com/gh_mirrors/pa/parse-dashboard Parse Dashboard是Parse Server的官方管理界面&#xff0c;为开发…

作者头像 李华
网站建设 2026/6/9 17:36:58

FanFicFare终极指南:3步快速上手网络小说下载神器

FanFicFare终极指南&#xff1a;3步快速上手网络小说下载神器 【免费下载链接】FanFicFare FanFicFare is a tool for making eBooks from stories on fanfiction and other web sites. 项目地址: https://gitcode.com/gh_mirrors/fa/FanFicFare FanFicFare是一款强大的…

作者头像 李华
网站建设 2026/6/11 15:57:04

计算机毕业设计|基于Java + vue水果商城系统(源码+数据库+文档)

水果商城系统 目录 基于springboot vue水果商城系统 一、前言 二、系统功能演示 详细视频演示 三、技术选型 四、其他项目参考 五、代码参考 六、测试参考 七、最新计算机毕设选题推荐 八、源码获取&#xff1a; 基于springboot vue水果商城系统 一、前言 博主介绍…

作者头像 李华
网站建设 2026/6/10 15:21:24

Cloudflare防火墙拦截谷歌爬虫|导致收录失败怎么解决?

许多站长发现网站突然从谷歌搜索结果中“消失”&#xff0c;背后很可能是Cloudflare防火墙误拦截了谷歌爬虫&#xff08;Googlebot&#xff09;&#xff0c;导致搜索引擎无法正常抓取页面。由于Cloudflare默认的防护规则较为严格&#xff0c;尤其是针对高频访问的爬虫IP&#x…

作者头像 李华