Java框架中的分层架构

分层架构

Entity层(实体层)

作用:定义数据模型,与数据库表结构对应

职责:封装业务对象的属性和基本操作

特点:通常是简单的POJO类,包含属性、getter/setter方法

示例:用户实体类User包含id、name、email等属性

Mapper层(持久层/数据访问层)

作用:负责与数据库交互,执行CRUD操作

职责:提供数据访问接口,实现SQL语句的执行

特点:通常使用MyBatis、JPA等框架实现

功能:将数据库记录映射为实体对象

Service层(业务逻辑层)

作用:处理具体的业务逻辑

职责:实现业务规则和流程控制,协调多个Mapper的操作,处理事务管理

特点:不关心具体的数据存储细节

Controller层(控制器层)

作用:接收HTTP请求并返回响应结果

职责:接收前端参数,调用相应的Service方法,返回视图或JSON数据

特点:关注请求路由、参数校验和响应格式

分层架构限制原则

单一职责原则

每个服务类只负责一个业务领域

避免在一个 Service 中混合多个不相关的业务逻辑

保持代码的可读性和可维护性

开闭原则

对扩展开放,对修改关闭

通过接口和抽象类实现灵活的业务扩展

避免频繁修改现有的稳定代码

接口隔离原则

Service 层提供细粒度的业务接口

避免臃肿的大接口,保持接口的专注性

客户端只依赖需要的接口方法

事务边界控制

事务管理集中在 Service 层

Controller 层不应处理事务逻辑

避免跨层的事务传播问题

异常处理分层

Mapper 层抛出数据访问异常

Service 层捕获并转换为业务异常

Controller 层统一处理异常响应

数据传输对象(DTO)规范

跨层传递使用专门的 DTO 对象

避免直接传递 Entity 对象

控制数据安全和格式标准化

依赖注入约束

严格遵循分层依赖关系

下层组件不能依赖上层组件

通过 @Autowired 或构造器注入实现解耦

跨模块Service调用限制

架构层次规范

Service层 应该作为业务逻辑的协调者

只能依赖同层级的其他 Service 组件

不应直接访问底层的 Mapper 数据访问层

依赖倒置原则

Controller → Service → Service → Mapper

遵循高层模块不依赖低层模块的原则

跨模块调用应该通过业务接口抽象

避免循环依赖

直接调用其他模块 Mapper 容易造成紧耦合

通过 Service 层调用可以解耦模块间的关系

维护清晰的模块边界

事务管理统一

Service 层统一处理事务边界

避免跨模块直接 Mapper 调用导致事务不一致

保证数据一致性

业务逻辑封装

Service 层提供完整的业务能力封装

不应暴露底层数据访问细节

保持业务逻辑的完整性

相关推荐
云烟成雨TD1 分钟前
Spring AI Alibaba 1.x 系列【56】SAA Admin 平台功能介绍
java·人工智能·spring
Gauss松鼠会1 分钟前
GaussDB(DWS) 资源监控Topsql
java·网络·数据库·算法·oracle·性能优化·gaussdb
Swuagg1 分钟前
Flutter 架构实践:从 0 到 1 构建智能眼镜应用
flutter·架构
夏日听雨眠1 分钟前
数据结构(快速排序)
java·数据结构·算法
薇茗3 分钟前
【初阶数据结构】 升沉有序的平仄 排序 3
c语言·开发语言·数据结构·算法·排序算法·文件归并排序
字节高级特工5 分钟前
C++11(一) 革新:右值引用与移动语义
java·开发语言·c++·人工智能·后端
郝学胜-神的一滴6 分钟前
系统设计 012:从用户系统出发,吃透缓存、数据库与高并发设计
java·数据库·python·缓存·php·软件构建
winlife_8 分钟前
嵌入式 MCP server vs 外挂桥接进程:引擎编辑器自动化的架构取舍
架构·自动化·编辑器·游戏引擎·架构设计·mcp·编辑器自动化
AI科技星9 分钟前
强哥德巴赫猜想(1+1)终极证明(2026 年5月 21 日)
开发语言·人工智能·算法·计算机视觉·量子计算
人道领域10 分钟前
【LeetCode刷题日记】654.最大二叉树:递归算法详解
java·算法·leetcode