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

【Spring Boot后端组件】SpringMVC介绍及使用

文章目录

  • SpringMVC介绍及使用
    • 一、简介
    • 二、核心组件
    • 三、请求流程图解
    • 四、常用注解介绍
      • 1.@RequestMapping
      • 2.@RequestParam
      • 3.@PathVariable
      • 4.@RequestBody
    • 五、依赖
    • 六、外部访问流程

SpringMVC介绍及使用

一、简介

SpringMVC 是 Spring 框架中的一个模块,用于构建基于 Web 的应用程序。它是一个实现了 MVC 设计模式 的 Web 框架,旨在帮助开发者更清晰地分离表示层(View)、控制层(Controller)和业务逻辑(Model)。

SpringMVC 是 Spring Framework 的一部分,可以与 Spring 的其他模块(如 Spring Boot、Spring Security、Spring Data)无缝整合。

二、核心组件

  1. DispatcherServlet(前端控制器)
    (1)Spring MVC 的核心类,所有的请求都先由它接收并分发。
    (2)它是整个请求处理流程的“总调度”。

  2. HandlerMapping(处理器映射器)
    (1)根据请求 URL 找到对应的 Controller(处理器)。
    (2)可以是注解(如 @RequestMapping)映射,也可以是配置映射。

  3. Controller(控制器)
    (1)由开发者编写,用于处理具体请求,执行业务逻辑并返回 Model 和 View。
    (2)通常通过注解 @Controller 或 @RestController 定义。

  4. ModelAndView(模型和视图)
    (1)控制器返回的对象,封装了数据模型和视图名。
    (2)Spring 根据视图名去查找具体的 View,并结合模型渲染页面。

  5. ViewResolver(视图解析器)
    (1)根据 Controller 返回的逻辑视图名,解析成具体的视图对象(如 JSP、Thymeleaf、HTML 等)。

  6. View(视图)
    (1)负责将数据渲染成最终页面,例如:JSP、HTML、Thymeleaf 模板等。

三、请求流程图解

客户端请求|v
DispatcherServlet (前端控制器)|v
HandlerMapping(找控制器)|v
Controller(处理请求逻辑)|v
返回ModelAndView(包含模型数据 + 视图名)|v
ViewResolver(找具体视图)|v
View(渲染)|v
响应返回客户端

四、常用注解介绍

注解说明
@Controller标识一个类是控制器组件
@RestController等价于 @Controller + @ResponseBody,用于返回 JSON 数据
@RequestMapping映射请求路径到方法(类/方法级别都可用)
@GetMapping / @PostMapping更具体的请求映射,常用于 RESTful 风格接口
@RequestParam获取 URL 查询参数
@PathVariable获取 URL 路径参数
@RequestBody获取请求体 JSON 并绑定到对象
@ResponseBody将返回值序列化成 JSON/XML 直接返回给前端

1.@RequestMapping

常用属性
(1)path 属性:接口路径。[] 数组,可以填写多个接口路径。
(2)values 属性:和 path 属性相同,是它的别名。
(3)method 属性:请求方法 RequestMethod ,可以填写 GET、POST、POST、DELETE 等等。[] 数组,可以填写多个请求方法。如果为空,表示匹配所有请求方法。

@RestController
@RequestMapping("/api/user")
public class HelloController {// 处理 GET 请求,路径为 /hello@RequestMapping(value = "/hello", method = RequestMethod.GET)public String sayHello() {return "Hello, Spring!";}
}

一般需要指定各方法具体的method,否则默认可以接受各种请求,存在安全隐患,以下是一些简化写法的派生注解,如@GetMapping@PostMapping

@RestController
@RequestMapping("/api/user")
public class HelloController {// 处理 GET 请求,路径为 /hello@GetMapping("/hello")public String sayHello() {return "Hello, Spring!";}
}
HTTP 方法注解作用幂等性常见用法
GET@GetMapping查询/获取数据是(安全)获取资源列表或详情
POST@PostMapping新建资源新增数据、提交操作
PUT@PutMapping全量更新资源替换整个资源
PATCH@PatchMapping局部更新资源视实现而定更新部分字段
DELETE@DeleteMapping删除资源删除指定资源

重点:
(1)在类上,添加 @RestController 注解,表示直接返回接口结果。默认情况下,使用 JSON 作为序列化方式。
(2)在类上,添加 @RequestMapping(“/api/user”) 注解,表示 HelloController 所有接口路径,以 /api/user 开头。

2.@RequestParam

常用注解
(1)name 属性:对应的请求参数名。如果为空,则直接使用方法上的参数变量名。
(2)value 属性:和 name 属性相同,是它的别名。
(3)required 属性:参数是否必须传。默认为 true ,表示必传。
(4)defaultValue 属性:参数默认值。

@RestController
@RequestMapping("/api/user")
public class HelloController {@GetMapping("/greet")public String greet(@RequestParam String name) {return "Hello, " + name + "!";}// 设置参数默认值和是否必填@GetMapping("/welcome")public String welcome(@RequestParam(name = "user", required = false, defaultValue = "Guest") String username) {return "Welcome, " + username;}// 接收多个参数@GetMapping("/add")public String add(@RequestParam int a, @RequestParam int b) {return "Sum: " + (a + b);}// 接收对象@GetMapping("/user")public String getUser(@RequestParam User user) {return "Name: " + user.getName() + ", Age: " + user.getAge();}// 接收参数列表@GetMapping("/tags")public String getTags(@RequestParam List<String> tags) {return "Tags: " + String.join(", ", tags);}
}

访问示例:
GET /api/user/greet?name=123 返回 “Hello, 123!”

重点
参数名和请求参数名一致时,可省略。如function(@RequestParam("paramName") String name)则不可省略。

3.@PathVariable

@RestController
@RequestMapping("/users")
public class UserController {// 请求路径:/users/123@GetMapping("/{id}")public String getUserById(@PathVariable("id") int userId) {return "User ID is: " + userId;}// 省略括号里的变量名,默认匹配参数名@GetMapping("/{name}/profile")public String getUserProfile(@PathVariable String name) {return "Profile of user: " + name;}
}

访问示例:
①GET /users/123 返回 “User ID is: 123”
②GET /users/tom/profile 返回 “Profile of user: tom”

重点
①@PathVariable(“id”) 绑定路径中 {id} 对应的值。
②如果方法参数名和路径变量名一致,可以省略括号里的名称,比如上面 @PathVariable String name。

4.@RequestBody

@RequestBody 是 Spring MVC 用来接收请求体(body)中的数据,通常用于接收 JSON、XML 或表单数据,自动把请求体内容转换成 Java 对象。

@RestController
public class UserController {@PostMapping("/user")public String createUser(@RequestBody User user) {return "Received user: " + user.getName() + ", age: " + user.getAge();}
}

五、依赖

<!-- 实现对 Spring MVC 的自动化配置 -->
<dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId>
</dependency>

Spring Boot 自动注册 DispatcherServlet,并内置 Tomcat,使得你可以直接编写控制器并启动项目。

六、外部访问流程

步骤说明
1. 应用启动,@SpringBootApplication 启动扫描自动扫描包路径下的 Controller 并注册
2. Spring MVC 根据映射处理请求URL 请求会匹配到对应 Controller 方法
3. 外部通过浏览器或 HTTP 客户端访问 URL访问控制器暴露的接口

所以要确保@controller类被扫描到

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

相关文章:

  • Android 11.0 动画缩放默认值改为0.5的功能实现
  • 电脑闪屏可能的原因
  • 微信学习之导航功能
  • linux编译安装srs
  • 第二届parloo杯的RSA_Quartic_Quandary
  • JAVA Web 期末速成
  • 题目练习之综合运用
  • el-tree结合el-tree-transfer实现穿梭框里展示树形数据
  • 电子电路:什么是静态工作点Q点?
  • 零基础设计模式——大纲汇总
  • 【Dify 前端源码解读系列】聊天组件功能分析文档
  • EtherCAT通讯框架
  • Node-Red通过Profinet转ModbusTCP采集西门子PLC数据配置案例
  • 开源表单设计器FcDesigner配置多语言教程
  • Go内存管理
  • 项目中把webpack 打包改为vite 打包
  • [CSS3]属性增强2
  • iOS热更新技术要点与风险分析
  • k8s节点维护的细节
  • SEO长尾词与关键词优化策略
  • Uniapp中动态控制scroll-view滚动的方式
  • Spring IOCDI————(1)
  • AG-UI 协议是什么?MCP、A2A 后,AI 领域又新增 AG-UI 协议
  • 50天50个小项目 (Vue3 + Tailwindcss V4) ✨ | Progress Steps (步骤条)
  • Windows环境安装LibreOffice实现word转pdf
  • Python----目标检测(PASCAL VOC数据集)
  • 艾默生流量计与Profibus DP主站转Modbus RTU/TCP网关通讯案例
  • Linux利用多线程和线程同步实现一个简单的聊天服务器
  • 数据库中的属性列数和元组
  • Java POJO接收前端null值设置