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

Spring Boot 分层架构详解:Controller、Service、Mapper...

在这里插入图片描述

在构建企业级后端应用时,良好的分层架构不仅能提升代码的可读性和可维护性,也能帮助团队实现职责清晰、功能复用的目标。本文将详细介绍
Spring Boot 项目中常见的分层结构,重点讲解 ControllerServiceMapper 各层的职责、使用方式与最佳实践。


📚 一、为什么要分层?

我们在开发 Spring Boot 项目时,并不是所有代码堆在一个类里,而是根据功能职责划分为不同的“层”,以实现:

  • 职责清晰
  • 降低耦合
  • 易于测试
  • 易于扩展和维护

这就是典型的 MVC(Model-View-Controller)+ Service + DAO 架构。


🧱 二、Spring Boot 项目的典型分层结构

层级英文名称主要职责是否写 SQL是否处理业务是否响应请求
表现层Controller接收前端 HTTP 请求、处理参数、调用业务逻辑、返回响应结果❌(只转发)
业务逻辑层Service封装业务逻辑、事务控制、调用数据访问接口、组织业务流程
数据访问层Mapper / DAO定义数据库操作,配合 XML 或注解执行 SQL
数据模型层Entity / Model封装数据库表结构对应的数据对象,进行前后端数据传输
配置层Config配置类,如数据源、拦截器、跨域处理、安全策略等
启动器层Application应用程序启动入口,加载配置并启动 Spring Boot 环境

📁 三、目录结构推荐

一个标准的 Spring Boot + MyBatis 项目结构如下:

src/└── main/├── java/com/example/demo/│   ├── controller/     // 接收请求│   ├── service/        // 编写业务逻辑│   ├── mapper/         // 与数据库交互│   ├── model/          // 数据对象(Entity)│   ├── config/         // 配置类│   └── DemoApplication.java└── resources/├── mapper/         // MyBatis XML 文件└── application.yml // 配置文件

🧩 四、各层职责详解

✅ 1. Controller —— 表现层

  • 接收 HTTP 请求(@GetMapping/@PostMapping
  • 处理请求参数(@RequestParam/@RequestBody
  • 调用 Service 进行业务处理
  • 返回响应结果(ResponseEntity/JSON

示例:

@RestController
@RequestMapping("/users")
public class UserController {@Autowiredprivate UserService userService;@GetMapping("/{id}")public User getById(@PathVariable Long id) {return userService.getUserById(id);}
}

✅ 2. Service —— 业务逻辑层

  • 编写业务逻辑(如注册、下单、积分计算等)
  • 事务控制(使用 @Transactional
  • 调用多个 Mapper 或外部服务
  • 拆分复杂业务流程,提升可复用性

示例:

@Service
public class UserService {@Autowiredprivate UserMapper userMapper;public User getUserById(Long id) {return userMapper.selectById(id);}
}

✅ 3. Mapper —— 数据访问层(DAO)

  • 编写 SQL 语句(使用 MyBatis 注解或 XML)
  • 与数据库进行交互(增删改查)
  • 不处理业务逻辑,仅作为数据库操作的封装器

示例(注解方式):

@Mapper
public interface UserMapper {@Select("SELECT * FROM user WHERE id = #{id}")User selectById(Long id);
}

示例(XML 方式):

<mapper namespace="com.example.demo.mapper.UserMapper"><select id="selectById" resultType="User">SELECT * FROM user WHERE id = #{id}</select>
</mapper>

✅ 4. Model —— 数据模型层

  • 定义实体类,用于封装数据库字段
  • 一般对应数据库中的一张表
  • 用作 Controller 与 Service 之间传递的数据对象

示例:

@Data
public class User {private Long id;private String username;private String email;
}

💡 五、常见疑问解答

❓1. Controller 可以代替 Service 吗?

从技术上讲:可以写在一起。
从架构上讲:绝对不推荐!

👉 原因:

  • Controller 是面向接口的,只管“接收”与“响应”
  • Service 专注处理业务,解耦逻辑,有利于测试、复用、事务控制

❓2. Controller 可以代替 Mapper 或 XML 吗?

完全不能。

  • Controller 不应该操作数据库;
  • Mapper/XML 专门用来写 SQL;
  • 控制层不应承担数据库逻辑。

✅ 六、总结

Controller 管接口,Service 管逻辑,Mapper 管数据库,Model 管数据结构。


http://www.lryc.cn/news/591663.html

相关文章:

  • SLG 游戏如何进行防破解和防盗版保护?
  • 《迭代器 VS 生成器:Python 惰性计算的两种实现方案详解》
  • Scrapy无缝集成Pyppeteer:异步无头浏览器爬虫架构实战
  • 中科固源深度解析:DoIP 协议原理、应用与安全防护全流程
  • cnpm命令报internal/modules/cjs/loader.js:797 throw err; ^ Error: Cannot find
  • 第12章 存储类、链接和内存管理
  • python学智能算法(二十二)|SVM-点与超平面的距离
  • Adam优化器
  • 深入理解 KVM 子系统:从虚拟化核心到内核实现的全景解析
  • js对象简介、内置对象
  • 【中等】题解力扣21:合并两个有序链表
  • mysql——搭建MGR集群
  • Python清屏方法大全 - 终端清屏的几种实现方式
  • 【Android】EditText使用和监听
  • ELN:生物医药科研的数字化引擎——衍因科技引领高效创新
  • H7-TOOL脱机下载后,自动重连RTT,CAN和串口助手三合一模式方法,方便项目测试(2025-07-16)
  • Cocos游戏中UI跟随模型移动,例如人物头上的血条、昵称条等
  • 对话弋途科技:当AI重构汽车大脑,一场车载操作系统的“觉醒年代“开始了
  • 数据呈现:让图表说话,从数字到洞察的可视化艺术
  • springmvc跨域解决方案
  • 移动安全工具-spd_dump
  • FOC算法中SIMULINK一些常用模块(2)-Permanent Magnet Synchronous Machine模块
  • 五分钟学会大数定律【笔记】
  • mysql 字符集不一致导致索引失效问题
  • 以Streamable HTTP方式访问mcp server的过程
  • 【机器学习实战【七】】机器学习特征选定与评估
  • C 语言基础第 08 天:数组与冒泡排序
  • c#笔记之方法的形参列表以及方法重载
  • ubuntu22 npm install electron --save-dev 失败
  • 设计模式是什么呢?