《Spring-MVC》系列文章目录

简介
Spring MVC是一种基于Java的实现MVC设计模式的请求驱动类型的轻量级Web框架,它通过把Model(模型)、View(视图)、Controller(控制器)分离,将web层进行职责解耦,把复杂的web应用分成逻辑清晰的几部分,简化开发,减少出错,方便测试。Spring MVC是Spring框架的一部分,使用Spring MVC可以非常方便的设计出干净的Web层。

在Spring MVC中,控制器(通常称作Dispatcher Servlet)实现了前端控制器设计模式,每个web请求必须通过它以便它能够管理整个请求的生命周期。当一个web请求发送到Spring MVC应用程序,dispatcher servlet首先接收请求,然后组织那些在Spring web应用程序上下文配置的(例如实际请求处理控制器和视图解析器)或者使用注解配置的组件,所有的这些都需要处理该请求。

Spring MVC具有许多优点,例如:

  1. 天然与Spring框架集成,如IoC容器、AOP等。
  2. 提供强大的约定大于配置的契约式编程支持。
  3. 能简单的进行Web层的单元测试。
  4. 支持灵活的URL到页面控制器的映射。
  5. 非常容易与其他视图技术集成,如Velocity、FreeMarker等。
  6. 具有非常灵活的数据验证、格式化和数据绑定机制,能使用任何对象进行数据绑定,不必实现特定框架的API。
  7. 支持灵活的本地化等解析。
  8. 具有更加简单的异常处理。
  9. 对静态资源的支持。
  10. 支持Restful风格。

高内聚低耦合,单一职责
随着前后端分离模式的流行,springmvc又衍生出了三层架构: 表现层(contorller), 业务逻辑层(service)和数据层.(dao)


流程
在这里插入图片描述SpringMVC的执行流程可以概括为以下几个主要步骤:
11. 发送请求:用户通过浏览器或其他客户端发送HTTP请求到服务器。

  1. 前端控制器接收请求:Spring MVC的前端控制器DispatcherServlet接收到请求。DispatcherServlet是Spring MVC的核心组件,它负责接收所有的请求并进行分发。

  2. 请求映射:DispatcherServlet根据请求的URL查找HandlerMapping,以确定处理该请求的Controller。HandlerMapping负责将URL映射到相应的Controller。

  3. 调用处理器:一旦找到了合适的Controller(也称为处理器或Handler),DispatcherServlet会调用处理器适配器执行该处理器来处理请求。处理器会根据业务逻辑处理请求,并生成一个ModelAndView对象。这个对象包含了视图的名字以及需要渲染到视图中的数据。

  4. 模型数据解析:在处理器生成ModelAndView对象后,如果模型数据中有自定义的类型,那么还需要通过ModelAndViewContainer进行数据类型转换和格式化,以便于视图解析和渲染。

  5. 视图解析:DispatcherServlet会将ModelAndView对象传递给ViewResolver进行视图解析。ViewResolver根据视图的名字解析出具体的视图实现类View,如JSP视图等。

  6. 视图渲染:视图实现类使用ModelAndView对象中的模型数据进行渲染,生成最终的响应结果(通常是HTML页面)。

  7. 返回响应:视图将渲染后的结果返回给DispatcherServlet,再由DispatcherServlet返回给客户端。


文章目录

开始学习吧

  1. 【第1章】spring-mvc搭建
  2. 【第2章】引入spring-mvc框架
  3. 【第3章】spring-mvc请求参数处理
  4. 【第4章】spring-mvc请求参数处理JSON数据
  5. 【第5章】spring-mvc请求映射处理
  6. 【第6章】spring-mvc之rest和filter
  7. 【第7章】spring-mvc静态资源(resources)
  8. 【第8章】spring-mvc视图解析器、控制器
  9. 【第9章】spring-mvc响应结果处理
  10. 【第10章】spring-mvc转发和重定向
  11. 【第11章】spring-mvc默认转换器
  12. 【第12章】spring-mvc自定义类型转换器
  13. 【第13章】spring-mvc之validator
  14. 【第14章】spring-mvc之ajax
  15. 【第15章】spring-mvc之文件上传和下载
  16. 【第16章】spring-mvc之多文件上传
  17. 【第17章】spring-mvc之日志和拦截器
  18. 【第18章】spring-mvc之国际化(i18n)
  19. 【第19章】spring-mvc之全局异常处理
  20. 【第20章】spring-mvc之定时任务
  21. 【第21章】spring-mvc之整合druid
  22. 【第22章】spring-mvc之缓存

常用注解

注解描述使用场景
@RequestMapping用于映射请求URL到特定的处理器方法可用在类或方法上,定义请求的URL路径
@GetMapping用于映射GET请求URL到特定的处理器方法可用在类或方法上,定义请求的URL路径
@PostMapping用于映射POST请求URL到特定的处理器方法可用在类或方法上,定义请求的URL路径
@PathVariable绑定URL模板变量到控制器方法的参数上用于从URL中获取参数值
@RequestParam绑定请求参数到控制器方法的参数上用于从请求中获取参数值
@RequestBody用于绑定请求参数到命令对象(通常是JavaBean)上用于处理表单提交的数据绑定
@RequestHeader用于绑定请求头到命令对象(通常是JavaBean)上用于处理表单提交的数据绑定
@ResponseBody表示该方法的返回结果直接写入HTTP响应体中用于返回JSON、XML等响应数据
@ResponseStatus返回HTTP响应状态码常用于400、404、500等界面
@RestController@Controller和@ResponseBody的组合注解用于创建RESTful Web服务的控制器
@RequestPart用于映射文件到 MultipartFile主要用于处理多部分请求,特别是当请求中包含文件上传时
@CookieValue用于绑定cookie到命令对象用于处理请求携带的cookie数据绑定
@SessionAttribute用于绑定session到命令对象用于处理请求携带的session数据绑定
@ControllerAdvice用于定义全局的异常处理、数据绑定处理以及请求/响应处理器用于创建一个或多个 @ExceptionHandler、@InitBinder 和 @ModelAttribute 方法,这些方法可以被多个 @Controller 使用
@RestControllerAdvice@ControllerAdvice和@ResponseBody的结合同上

这些注解在Spring MVC框架中是非常常用和重要的,它们帮助开发者更简洁、高效地处理HTTP请求和构建Web应用。每个注解都有其特定的使用场景和功能,开发者可以根据实际需求选择使用。


视频学习
官方文档
中文文档

视频中版本比较低,接下来我用新版本作为演示,视频中讲解的太细了,🆗;
官方文档,对每个点都介绍的比较细,但是没有提供样例代码,可以作为参考使用;
中文文档优点是中文,缺点是和最新版差了一个大版本,有总比没有强;
我负责把最精华、最干货的内容总结给大家;
带家人们学习最新的技术,推荐大家跟着我的博客学习,有问题可以评论或私聊我,尽力帮助大家。

诚邀您点击一下“关注”按钮,您的支持是我坚持创作的动力。

在这里插入图片描述
《Spring》系列文章目录

  • 13
    点赞
  • 27
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
`feign-spring-mvc-starter` 是一个 Feign 的扩展,它支持使用 Spring MVC 注解来定义和调用 REST 服务。使用 `feign-spring-mvc-starter`,你可以像使用 Spring MVC 控制器一样定义 Feign 客户端,从而更方便地进行 REST 服务的开发。 在使用 `feign-spring-mvc-starter` 之前,你需要先了解 Feign 和 Spring MVC 的基本概念和用法。 Feign 是一个声明式的 Web 服务客户端,它可以帮助你更方便地定义和调用 REST 服务。Feign 的基本使用方法是定义一个接口,用于描述 REST 服务的 API,然后使用 Feign 注解来声明这个接口。 Spring MVC 是一个基于 Java 的 Web 框架,它提供了一组注解和 API,用于处理 Web 请求和响应。 `feign-spring-mvc-starter` 将 Feign 和 Spring MVC 结合起来,使你可以使用 Spring MVC 注解来定义和调用 REST 服务。使用 `feign-spring-mvc-starter`,你可以更方便地使用 Feign 来调用 REST 服务。 以下是一个使用 `feign-spring-mvc-starter` 的示例: 1. 添加 Maven 依赖 在 pom.xml 文件中添加以下依赖项: ```xml <dependency> <groupId>io.github.openfeign</groupId> <artifactId>feign-spring-mvc</artifactId> <version>5.3.1</version> </dependency> ``` 2. 定义 Feign 接口 定义一个 Feign 接口,用于描述 REST 服务的 API。例如: ```java @FeignClient(name = "example-service") public interface ExampleClient { @GetMapping("/example") String getExample(); } ``` 在这个接口中,我们使用了 `@FeignClient` 注解来声明这个接口是一个 Feign 客户端,并指定了服务的名称。然后,我们定义了一个 `getExample()` 方法,用于调用 example-service 服务的 /example 路径。 3. 定义 Spring MVC 控制器 定义一个 Spring MVC 控制器,用于处理来自客户端的请求。例如: ```java @RestController public class ExampleController { private final ExampleClient exampleClient; public ExampleController(ExampleClient exampleClient) { this.exampleClient = exampleClient; } @GetMapping("/") public String index() { return exampleClient.getExample(); } } ``` 在这个控制器中,我们注入了 `ExampleClient`,并在 `index()` 方法中使用它来调用 example-service 服务的 /example 路径。 4. 运行应用程序 现在,你可以运行应用程序并访问 http://localhost:8080/ ,你应该会看到来自 example-service 服务的响应。 这就是一个使用 `feign-spring-mvc-starter` 的示例。使用 `feign-spring-mvc-starter`,你可以更方便地使用 Feign 来调用 REST 服务。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值