当前位置: 首页 > news >正文

java开发的三层架构

三层架构

三层架构把程序分成三部分,各司其职,便于维护与扩展:
Controller(控制层 / 接口层)→ Service(业务层)→ Mapper/DAO(持久层)


概览

  • 目标:每层只做一类事,职责单一,降低耦合。
  • 好处:易维护、易测试、易扩展、便于多人协作。

Controller(控制层 / 接口层)

前台接待与传话筒。

主要职责

  • 接收请求(URL、Headers、Body、参数)。
  • 做入参校验(是否缺失、格式是否合法、简单鉴权)。
  • 调用 Service,传递必要参数。
  • 封装 Service 返回值为响应格式(JSON/HTTP status),返回给前端。

不该做

  • 不实现复杂业务逻辑。
  • 不写 SQL、不直接访问数据库。

原则

  • 薄控制层:只做协调与验证,保持简单易读。

Service(业务层)

业务逻辑的大脑。

主要职责

  • 实现业务规则(权限判断、折扣规则、状态机、事务编排等)。
  • 组织调用多个 Mapper 或第三方服务,串联业务流程。
  • 处理事务边界(开启/提交/回滚)。
  • 返回业务结果给 Controller。

不该做

  • 不直接操作 SQL 或处理请求/响应的细节(HTTP、序列化等)。

原则

  • 业务集中化、可复用、可单元测试。尽量纯粹(无 UI/协议依赖)。

Mapper / DAO(持久层)

数据库搬运工与翻译官。

主要职责

  • 执行 SQL(查询/插入/更新/删除)。
  • 将数据库记录映射为实体对象(Entity/POJO),或将对象转换为 SQL 参数。
  • 提供基础的增删改查接口给 Service 使用。

不该做

  • 不处理复杂业务规则、不做跨表业务决策。

原则

  • 单一职责:只关心数据持久化与映射,保持稳定、可替换(例如切换 ORM 或数据库)。

请求/数据流(简明)

前端请求 ↓ Controller(校验、解析) ↓ Service(业务逻辑、事务、调用多个 Mapper) ↓ Mapper/DAO(执行 SQL、返回实体) ↓ Service(整合结果) ↓ Controller(封装为 JSON) ↓ 前端收到响应

快速对照表

主要角色做什么不做
Controller接口/路由接收请求、校验、转交、响应写业务、写 SQL
Service业务逻辑核心逻辑、流程编排、事务直接操作数据库、处理 HTTP 细节
Mapper/DAO持久化执行 SQL、对象映射写业务规则、处理事务决策

常见示例流程(订单更新)

  1. 前端发来更新订单请求(/orders/123/update)。
  2. Controller 校验 token、校验参数是否完整。
  3. Controller 调用OrderService.updateOrder(userId, orderDto)
  4. Service 检查用户权限、校验订单状态、开始事务。
  5. Service 调用OrderMapper.selectById(123)InventoryMapper.decrease(...)等。
  6. Mapper 执行 SQL 并返回实体。
  7. Service 整合结果,提交事务,返回业务结果。
  8. Controller 将结果封装为 JSON 并返回前端。

结论

三层架构让“接待(Controller)→ 决策(Service)→ 搬运(Mapper)”各自专注,系统更清晰、可维护、可测试。

http://www.jsqmd.com/news/295479/

相关文章:

  • 企业微信智能定位:非ROOT环境下的异地打卡解决方案
  • AI抠图边缘有白边?科哥镜像参数调整技巧
  • 7个技巧掌握AI语音识别字幕工具:多语言字幕生成与翻译全解析
  • Sambert音频合成卡顿?GPU算力动态分配优化实战
  • 一文说清nmodbus4类库使用教程的基础操作流程
  • 4步实现音乐自由:解锁加密音频的全平台解决方案
  • 企业微信打卡定位全攻略:从入门到精通的6种解决方案
  • macOS证书配置网络嗅探解决方案:从问题排查到效能优化
  • 开源硬盘监控工具全攻略:从故障预警到数据安全防护
  • 高效转换B站缓存视频:跨平台播放的零基础解决方案
  • Hackintool黑苹果配置工具:解决硬件适配与系统优化的实用指南
  • 高效获取B站字幕的实用技巧:3步轻松搞定视频字幕提取
  • 3分钟上手的字幕黑科技:B站字幕提取、下载与格式转换全攻略
  • 如何用智能歌词管理工具解决90%的音乐歌词烦恼?
  • 音频格式转换工具:告别格式枷锁,实现跨设备音乐自由
  • Qwen2.5-0.5B输出乱码?编码格式问题排查指南
  • RuoYi-Flowable-Plus零基础上手指南:从安装到实战的避坑全攻略
  • Sambert-HiFiGAN如何快速上手?保姆级语音合成部署教程入门必看
  • 如何用LyricsX打造专属音乐体验:Mac用户的个性化歌词解决方案
  • Qwen2.5-0.5B批量处理能力:多请求并行优化部署案例
  • Safe Exam Browser 虚拟机检测绕过工具研究指南
  • 2024桌面歌词小白友好指南:让音乐体验升级的同步工具
  • 开源模型部署趋势:Qwen All-in-One引领轻量化风潮
  • 企业微信智能定位管理:突破传统打卡限制的3大创新实践
  • Steam游戏DRM解除工具全攻略:从入门到精通的自动化解决方案
  • 解锁3大效能:虚拟ZPL打印机实战指南
  • Qwen1.5-0.5B性能瓶颈突破:CPU算力适配实战
  • 不用cron也能自启!更适合长期运行的任务
  • 3分钟解锁全网歌词!这款智能歌词提取神器让音乐体验升舱
  • verl框架扩展性测试:跨平台部署实战指南