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

springboot入门-controller层

在 Spring Boot 中,Controller 层是处理 HTTP 请求的核心组件,负责接收客户端请求、调用业务逻辑(Service 层)并返回响应。其核心原理基于 Spring MVC 框架,通过注解驱动的方式实现请求的路由和参数绑定。以下是 Controller 层的核心原理、路由机制及常用注解的详细说明:


1. Spring Boot 的请求处理流程

Spring Boot 使用 DispatcherServlet 作为前端控制器(Front Controller),统一接收所有 HTTP 请求,并按以下流程路由到 Controller:

  1. 接收请求
    DispatcherServlet 拦截所有请求(默认路径 /)。
  2. 查找处理器
    通过 HandlerMapping 找到匹配请求路径的 Controller 方法(如 @GetMapping("/users"))。
  3. 调用处理器
    使用 HandlerAdapter 执行目标方法,处理参数绑定和返回值。
  4. 处理返回值
    通过 ViewResolverHttpMessageConverter 将返回值转换为 JSON/XML 响应。
  5. 返回响应
    将处理结果写回客户端。

2. 路由机制:如何映射到 Controller?

Spring Boot 通过 注解 将 HTTP 请求的 URL 和 HTTP 方法(GET/POST 等)映射到具体的 Controller 方法。以下是关键步骤:

(1) 定义 Controller 类

使用 @RestController@Controller 标记类为请求处理器。

@RestController // 标记为 REST 控制器(自动返回 JSON 数据)
@RequestMapping("/api") // 类级别的公共路径
public class UserController {// 方法级别的路由...
}
(2) 定义路由方法

使用 @GetMapping@PostMapping 等注解标记方法,绑定 URL 和 HTTP 方法。

@GetMapping("/users/{id}") // 处理 GET /api/users/1 请求
public User getUser(@PathVariable Long id) {// 调用 Service 层逻辑...
}
(3) 路由匹配规则
  • 路径匹配:支持精确匹配、路径变量({id})、通配符(/files/**)。
  • HTTP 方法匹配:如 GETPOSTPUTDELETE
  • 内容协商:根据请求头 Accept 决定返回 JSON 或 XML。

3. 主要注解详解

(1) @RestController
  • 作用
    组合 @Controller@ResponseBody,表示该类所有方法直接返回数据(非视图)。
  • 示例
    @RestController
    public class UserController {// 方法返回 User 对象会被自动转换为 JSON@GetMapping("/user")public User getUser() { ... }
    }
    
(2) @RequestMapping
  • 作用
    定义请求的 URL 路径和 HTTP 方法,是其他注解(如 @GetMapping)的元注解。
  • 参数
    参数名作用示例
    value请求路径@RequestMapping("/users")
    methodHTTP 方法method = RequestMethod.GET
  • 示例
    @RequestMapping(value = "/users", method = RequestMethod.GET)
    public List<User> getUsers() { ... }
    
(3) @GetMapping@PostMapping
  • 作用
    @RequestMapping 的快捷方式,分别对应 HTTP 方法(GET、POST 等)。
  • 示例
    @GetMapping("/users")      // 等价于 @RequestMapping(method = GET)
    @PostMapping("/users")     // 等价于 @RequestMapping(method = POST)
    @PutMapping("/users/{id}") // 等价于 @RequestMapping(method = PUT)
    
(4) @RequestBody
  • 作用
    将 HTTP 请求体中的 JSON/XML 数据绑定到方法参数对象。
  • 示例
    @PostMapping("/users")
    public User createUser(@RequestBody User user) { // 自动反序列化 JSON 到 User 对象return userService.save(user);
    }
    
(5) @PathVariable
  • 作用
    绑定 URL 路径变量到方法参数。
  • 示例
    @GetMapping("/users/{id}")
    public User getUser(@PathVariable Long id) { // 将 URL 中的 {id} 绑定到参数 idreturn userService.findById(id);
    }
    
(6) @RequestParam
  • 作用
    绑定请求参数(URL 查询参数或表单数据)到方法参数。
  • 示例
    @GetMapping("/search")
    public List<User> searchUsers(@RequestParam String keyword) { // ?keyword=xxxreturn userService.search(keyword);
    }
    

4. 完整的 Controller 示例

@RestController
@RequestMapping("/api/users")
public class UserController {private final UserService userService;public UserController(UserService userService) {this.userService = userService;}// GET /api/users/1@GetMapping("/{id}")public User getUser(@PathVariable Long id) {return userService.findById(id);}// POST /api/users@PostMapping@ResponseStatus(HttpStatus.CREATED)public User createUser(@RequestBody User user) {return userService.save(user);}// GET /api/users/search?name=xxx@GetMapping("/search")public List<User> searchUsers(@RequestParam String name) {return userService.findByName(name);}
}

5. 请求参数绑定流程

  1. URL 路径变量
    通过 @PathVariable 绑定路径中的变量(如 /users/{id})。
  2. 请求参数
    通过 @RequestParam 绑定 URL 查询参数或表单数据(如 ?name=xxx)。
  3. 请求体数据
    通过 @RequestBody 绑定 JSON/XML 数据到对象。
  4. 请求头信息
    通过 @RequestHeader 绑定请求头(如 @RequestHeader("Authorization"))。

6. 响应处理

  • 返回对象
    使用 @RestController 时,返回值会被自动序列化为 JSON/XML(通过 HttpMessageConverter)。
  • 状态码控制
    使用 @ResponseStatus 指定 HTTP 状态码:
    @PostMapping
    @ResponseStatus(HttpStatus.CREATED) // 返回 201 Created
    public User createUser(...) { ... }
    

7. 常见问题

(1) 路径冲突怎么办?

Spring Boot 按 最长匹配优先 原则选择路由。例如:

@GetMapping("/users/{id}")      // 匹配 /users/1
@GetMapping("/users/new")       // 优先匹配 /users/new
(2) 如何处理文件上传?

使用 @RequestParamMultipartFile

@PostMapping("/upload")
public String uploadFile(@RequestParam("file") MultipartFile file) { ... }
(3) 如何返回 XML 数据?
  • 添加 XML 依赖(如 jackson-dataformat-xml)。
  • 设置请求头 Accept: application/xml

总结

注解作用常见使用场景
@RestController标记类为 REST 控制器,返回 JSON/XML 数据所有 RESTful API 的入口类
@GetMapping处理 GET 请求查询数据
@PostMapping处理 POST 请求创建数据
@RequestBody绑定请求体数据到对象接收 JSON/XML 格式的请求体
@PathVariable绑定 URL 路径变量根据 ID 查询资源
@RequestParam绑定 URL 查询参数或表单数据分页、过滤条件

通过合理使用这些注解,可以快速构建清晰、高效的 RESTful API,实现请求的路由、参数绑定和响应处理。

http://www.xdnf.cn/news/2123.html

相关文章:

  • IT社团分析预测项目(pandas、numpy、sklearn)
  • PMP-第一章 引论
  • 基于Docker、Kubernetes和Jenkins的百节点部署架构图及信息流描述
  • 微信小程序,基于uni-app的轮播图制作,调用文件中图片
  • 【计算机网络】TCP的四种拥塞控制算法
  • 深圳举办2025年全国儿童预防接种日主题宣传活动 全生命周期健康守护再升级
  • Win下Pycharm运行/调试配置脚本形参执行替换Linux下终端执行,进行调试需要注意的
  • MyBatis XML 配置完整示例(含所有核心配置项)
  • Unity中数据储存
  • 【Linux】Centos7 安装 Docker 详细教程
  • 7.学习笔记-Maven进阶(P75-P89)-进度(p75-P80)
  • Prometheus、Zabbix 和 Nagios 这三个工具的对100个节点的部署设计的信息流
  • Python Cookbook-6.11 缓存环的实现
  • 深入理解TransmittableThreadLocal:原理、使用与避坑指南
  • java智慧城管综合管理系统源码,前端框架:vue+element;后端框架:springboot;移动端:uniapp开发,技术前沿,可扩展性强
  • 代码随想录算法训练营Day31 | 56. 合并区间 738.单调递增的数字
  • 栈相关算法题解题思路与代码实现分享
  • 【Pandas】pandas DataFrame rmul
  • 2024江西ICPC部分题解
  • 数据分析管理软件 Minitab 22.2.2 中文版安装包 免费下载
  • 【Hive入门】Hive分桶表深度解析:从哈希分桶到Join优化的完整指南
  • 数字技术驱动下教育生态重构:从信息化整合到数字化转型的路径探究
  • 【摩尔定律】
  • Python爬虫实战:获取高考资源网各学科精品复习资料
  • C#中的弱引用使用
  • Set的学习
  • Eclipse Debug 配置指南
  • A. Ideal Generator
  • Maven 依赖冲突调解与版本控制
  • 百度AI开发者大会:连发多款AI应用,覆盖AI数字人等热门赛道