springboot入门-controller层

news2025/7/15 14:39:29

在 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} 绑定到参数 id
        return userService.findById(id);
    }
    
(6) @RequestParam
  • 作用
    绑定请求参数(URL 查询参数或表单数据)到方法参数。
  • 示例
    @GetMapping("/search")
    public List<User> searchUsers(@RequestParam String keyword) { // ?keyword=xxx
        return 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.coloradmin.cn/o/2343841.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

逆向|dy|a_bogus|1.0.1.19-fix.01

2025-04-26 请求地址:aHR0cHM6Ly93d3cuZG91eWluLmNvbS91c2VyL01TNHdMakFCQUFBQV96azV6NkoyMG1YeGt0eHBnNkkzRVRKejlyMEs3d2Y2dU9EWlhvd2ttblZWRnB0dlBPMmMwN2J0WFotcVU4V3M 个人主页的视频数据 我们需要逆向这个接口,所以现在需要分析这个请求, 分析这几个数据包可以发现: 只有…

高效使用DeepSeek对“情境+ 对象 +问题“型课题进行开题!

目录 思路"情境 对象 问题"型 课题选题的类型有哪些呢&#xff1f;这要从课题题目的构成说起。通过对历年来国家社会科学基金立项项目进行分析&#xff0c;小编发现&#xff0c;课题选题类型非常丰富&#xff0c;但一般是围绕限定词、研究对象和研究问题进行不同的组…

springboot项目配置nacos,指定使用环境

遇到这样一个问题&#xff0c;在开发、测试、生成环境之间切换的问题。 大多数的操作是通过修改spring.profiles.active来确定指向使用的环境配置文件&#xff0c;对应项目中需要增加对应的配置文件。 但是现在几乎所有公司都会有代码管理不管是SVN、git&#xff0c;这样就会涉…

DIFY 浅尝 - DIFY + Ollama 添加模型

准备物料 Dify 本地部署 Ollama 下载 Open WebUI 好了现在&#xff0c;假设访问 http://localhost/apps 应该可以打开 Dify&#xff0c;设置用户登录后应该可以看到以下界面 打开 http://localhost:3000/, 你应该可以看到部署好的Open WebUI&#xff0c;并假设有下载好你感…

Java 异常处理全解析:从基础到自定义异常的实战指南

Java 异常处理全解析&#xff1a;从基础到自定义异常的实战指南 一、Java 异常体系&#xff1a;Error 与 Exception 的本质区别 1. 异常体系核心架构 Java把异常当作对象来处理&#xff0c;并定义一个基类java.lang.Throwable作为所有异常的超类。 在Java API中已经定义了许…

开源AI智能名片链动2+1模式S2B2C商城小程序源码赋能下的社交电商创业者技能跃迁与价值重构

摘要&#xff1a;在移动互联网深度重构商业生态的背景下&#xff0c;社交电商创业者面临流量成本攀升、用户粘性不足、供应链协同低效等核心痛点。本文以“开源AI智能名片链动21模式S2B2C商城小程序源码”技术体系为研究对象&#xff0c;通过分析其技术架构、商业逻辑及实战案例…

WSL 中 nvidia-smi: command not found的解决办法

前言 在使用基于 Linux 的 Windows 子系统&#xff08;WSL&#xff09;时&#xff0c;当我们执行某些操作后&#xff0c;可能会遇到输入 nvidia-smi 命令却无法被系统识别的情况。 例如&#xff0c;在终端中输入nvidia-smi 后&#xff0c;系统返回提示 -bash: nvidia-smi: co…

FPGA前瞻篇-组合逻辑电路设计-多路复用器

多路选择器&#xff08;MUX&#xff09;简介 基本概念 多路选择器&#xff08;MUX&#xff0c;Multiplexer&#xff09;是一种多输入、单输出的组合逻辑电路。 它通过选择控制信号&#xff0c;在多个输入信号中选择一个连接到输出端。 可以理解为一个多路数字开关。 &…

【Castle-X机器人】五、物联网模块配置与调试

持续更新。。。。。。。。。。。。。。。 【Castle-X机器人】五、物联网模块配置与调试 五、物联网模块配置与调试5.1 物联网模块调试物联网模块测试:控制物联网模块:物联网模块话题五、物联网模块配置与调试 5.1 物联网模块调试 调试前需确保Castle-x与mqtt主机服务器处于同…

20250426在ubuntu20.04.2系统上打包NanoPi NEO开发板的FriendlyCore系统刷机eMMC的固件

20250426在ubuntu20.04.2系统上打包NanoPi NEO开发板的FriendlyCore系统刷机eMMC的固件 2025/4/26 21:30 缘起&#xff1a;使用NanoPi NEO开发板&#xff0c;编译FriendlyCore系统&#xff0c;打包eMMC固件的时候报错。 1、在ubuntu14.04下git clone异常该如何处理呢&#xff…

JAVA---字符串

ctrlN 搜索界面&#xff08;idea&#xff09; API和API帮助文档 API &#xff1a; 应用程序编程接口&#xff08;换句话说&#xff0c;就是别人已经写好了&#xff0c;我们不需要再编写&#xff0c;直接使用即可&#xff09; Java API &#xff1a;就是JDK中提供的各种功能…

MacOS 10.15上能跑大语言模型吗?

MacOS 10.15上能跑大语言模型吗&#xff1f; 下载安装Ollama运行大语言模型引申出的问题 MacOS 10.15.7&#xff08;发布于2020年9月&#xff09;作为已经发布了将近5年的系统版本能够运行当今流行的大语言模型吗&#xff1f;这篇文章简要介绍了在MacOS 10.15上通过Ollama运行d…

AI Agent开发第37课-DeepSeek的多模态版JanusPro-7B本地安装

开篇 搜遍Janus Pro git issues、谷哥、国内网络,教程全都是错的。因此还是决定写一本全网唯一正确的教程。 目前网上的教程包括外网的教程都是“缺斤少量”,按照那些教程操作下来不是装不起来,就是装起来只能CPU运行,或者运行起来了Janus的Web前端老是转啊转不出内容。 …

神经网络笔记 - 感知机

一 感知机是什么 感知机&#xff08;Perceptron&#xff09;是一种接收输入信号并输出结果的算法。 它根据输入与权重的加权和是否超过某个阈值&#xff08;threshold&#xff09;&#xff0c;来判断输出0还是1。 二.计算方式 感知机的基本公式如下&#xff1a; X1, X2 : …

阿里云基于本地知识库构建RAG应用 | 架构与场景

RAG&#xff08;检索增强生成&#xff0c;Retrieval-Augmented Generation&#xff09;是一种结合了检索和生成技术的框架&#xff0c;旨在通过外部知识库的检索来增强大语言模型&#xff08;LLM&#xff09;的生成能力。 其核心架构包括两个主要部分&#xff1a; 检索模块&a…

CSS简单实用的加载动画、骨架屏有效果图

效果图 .wxml <!-- 骨架屏 --> <view wx:for"{{skeleton}}" wx:key"index" class"container center" style"--w:{{item.w}}rpx;--h:{{item.h}}rpx" /> <!-- 加载 --> <view class"arco-loading center&quo…

3:QT联合HALCON编程—海康相机SDK二次程序开发

思路&#xff1a; 1.定义带UI界面的主函数类 1.1在主函数中包含其它所有类头文件&#xff0c;进行声明和实例化&#xff1b;使用相机时&#xff0c;是用公共相机的接口在某一个具体函数中去实例化具体的海康相机对象。 1.2设计界面&#xff1a;连接相机&#xff0c;单次采集&a…

【前后端分离项目】Vue+Springboot+MySQL

文章目录 1.安装 Node.js2.配置 Node.js 环境3.安装 Node.js 国内镜像4.创建 Vue 项目5.运行 Vue 项目6.访问 Vue 项目7.创建 Spring Boot 项目8.运行 Spring Boot 项目9.访问 Spring Boot 项目10.实现 Vue 与 Spring Boot 联动11.安装 axios12.编写请求13.调用函数请求接口14.…

数据结构和算法(八)--2-3查找树

目录 一、平衡树 1、2-3查找树 1.1、定义 1.2、查找 1.3、插入 1.3.1、向2-结点中插入新键 1.3.2、向一棵只含有一个3-结点的树中插入新键 1.3.3、向一个父结点为2-结点的3-结点中插入新键 1.3.4、向一个父结点为3-结点的3-结点中插入新键 1.3.5、分解根结点 1.4、2…

Unity-Shader详解-其二

前向渲染和延迟渲染 前向渲染和延迟渲染总的来说是我们的两种主要的渲染方式。 我们在Unity的Project Settings中的Graphic界面能够找到渲染队列的设定&#xff1a; 我们也可以在Main Camera这里进行设置&#xff1a; 那这里我们首先介绍一下两种渲染&#xff08;Forward R…