我以为我对Spring MVC很了解,直到我遇到了...

简介: 所有人都知道Spring MVC是是开发的,却鲜有人知道Spring MVC的理论基础来自于1978 年提出MVC模式的一个老头子,他就是Trygve Mikkjel Heyerdahl Reenskaug,挪威计算机科学家,名誉教授。Trygve Reenskaug的MVC架构思想早期用于图形用户界面(GUI) 的软件设计,他对MVC是这样解释的。MVC 被认为是解决用户控制大型复杂数据集问题的通用解决方案。最困难的部分是为不同的架构组件想出好的名字。模型-视图-编辑器是第一个。

点赞再看,Java进阶一大半

所有人都知道Spring MVC是Rod Johnson是开发的,却鲜有人知道Spring MVC的理论基础来自于1978 年提出MVC模式的一个老头子,他就是Trygve Mikkjel Heyerdahl Reenskaug,挪威计算机科学家,奥斯陆大学名誉教授。

Trygve Reenskaug的MVC架构思想早期用于图形用户界面(GUI) 的软件设计,他对MVC是这样解释的。

MVC 被认为是解决用户控制大型复杂数据集问题的通用解决方案。最困难的部分是为不同的架构组件想出好的名字。模型-视图-编辑器是第一个。经过长时间的讨论,特别是与Adele Goldberg的讨论,我们最终采用了模型-视图-控制器这个术语。

大家可以看看下面Trygve Reenskaug对MVC架构思想的理解与介绍

在这里插入图片描述

在这里插入图片描述

大家好,我是南哥。

一个Java进阶的领路人,今天指南的是Spring MVC,跟着南哥我们一起Java进阶。

本文收录在我开源的《Java进阶指南》中,一份帮助小伙伴们进阶Java、通关面试的Java学习面试指南,相信能帮助到你在Java进阶路上不迷茫。南哥希望收到大家的 ⭐ Star ⭐支持,这是我创作的最大动力。GitHub地址:https://github.com/hdgaadd/JavaProGuide

1. Spring MVC概况

1.1 如何理解Spring MVC

大家都知道Spring MVC很强大,南哥问大家一个问题,Spring MVC为什么会出现?一项技术的出现必定是为了解决旧技术考虑不全所积累的软件熵。《程序员修炼之道》在软件的熵一节中对熵的解释很有冲击力,作者是这么说的,大家有没什么触动。

虽然软件开发不受绝大多数物理法则的约束,但我们无法躲避来自熵的增加的重击。熵是一个物理学术语,它定义了一个系统的“无序”总量。不幸的是,热力学法则决定了宇宙中的熵会趋向最大化。当软件中的无序化增加时,程序员会说“软件在腐烂”。有些人可能会用更乐观的术语来称呼它,即“技术债”,潜台词是说他们总有一天会偿还的——恐怕不会还了。

在没有出现Spring MVC之前,老一代的开发者会在Servlet中编写业务逻辑和控制代码,甚至属于后端的业务逻辑也会耦合在了jSP页面。在当时互联网不流行,业务都比较简单的年代,这样写问题不会太大,但随着时间的累积、互联网的爆发,业务复杂度也爆发式上升,这叫新来的实习生程序员怎么上手呢。缺乏统一和清晰的架构模式,会导致应用程序的可扩展性和可维护性降低。

我们先不讲Spring MVC,把MVC拆解出来。MVC(Model View Controller)实践上是一种软件架构思想,这个思想指导把应用程序分为了三个模块,用于编写业务逻辑的模型、用于数据呈现的视图、用于协调前两者的控制器。

在我们Java程序员第一次接触企业框架时,我们最开始一般用SSM来练练手。如果是SSM框架,充当Model的是编写业务逻辑Java类,充当View的是JSP页面,而充当Controller的则是Servlet。总的来说,MVC明确划分了各个模块的责任,不是你负责的东西不允许越线,这明显维护起来好看多了。

好久好久之前南哥练手的第一个项目是坦克大战,和现在一般企业业务把一个Java对象看出是需求的抽象不同,我当时的坦克大战是把一个Java对象看成是一只坦克的载体。大家第一个Java练手项目有什么故事吗?

2. Spring MVC技术要点

2.1 Spring MVC工作流程

Spring MVC工作流程涉及五大组件,大家先预览一遍:DispatcherServlet、HandleMapping、Controller、ModelAndView、ViewResolver。

第一步用户触发浏览器时将请求发送给前端控制器DispatcherServlet,DispatcherServlet就相当于上文MVC架构的C,Spring源码对DispatcherServlet解释为HTTP请求处理程序/ 控制器的中央调度程序。有了中央调度程序大脑,下一步就可以联调其他组件了。

// DispatcherServlet类
package org.springframework.web.servlet;
public class DispatcherServlet extends FrameworkServlet {
   
    }

第二步,DispatcherServlet调用处理器映射器HandleMapping,根据用户请求的URL找到对应的业务控制器Contorller。

// HandlerMapping类
package org.springframework.web.reactive;
public interface HandlerMapping {
   
    }

第三步,DispatcherServlet请求处理器适配器HandlerAdapter执行Controller,获得业务结果后返回一个模型视图对象ModelAndView给到DispatcherServlet。

// ModelAndView类
package org.springframework.web.servlet;
public class ModelAndView {
   
   
// HandlerAdapter类
package org.springframework.web.servlet;
public interface HandlerAdapter {
   
    }

第四步,DispatcherServlet把ModelAndView返回给视图解析器ViewResolver,将ModelAndView解析为视图对象View。

// ViewResolver类
package org.springframework.web.servlet;
public interface ViewResolver {
   
   

最后一步,View会负责渲染,同时把结果返回给浏览器。

2.2 Spring MVC搭配Tomcat容器

大家有搭过Spring Web MVC框架的话就有印象,我们要在本机安装单独的一个Tomcat服务器,Tomcat搭配Spring框架才能让我们的Web应用程序跑起来。会不会觉得很麻烦,南哥觉得好麻烦。。

SpringBoot框架则不需要我们单独去部署一个Tomcat服务器,大家甚至在https://start.spring.io/官网下载包后,本地启动就可以把Web程序跑起来,方便吧。

这是为什么?SpringBoot内置了一个Servlet容器,而上文南哥所说的Tomcat容器本质也是一个Servlet容器,SpringBoot默认为我们配置的是Tomcat。要是对Tomcat不满意,你也可以用其他Servlet容器,比如Jetty、Undertow。

Tomcat容器为我们的Spring MVC做了很多脏活,例如底层Socket连接这种麻烦工作。而上文我提到的Spring MVC五大组件本质上都是调用Servlet API,而Servlet API的实现也是由Tomcat容器为我们完成的。

在Spring Web MVC框架里,如果大家要单独部署Servlet容器,切记注意下Spring框架和Servlet 容器的兼容性。在Spring官方文档中,Spring Framework 5.3.x 支持的最后一个Servlet规范版本4.0,从 Spring Framework 6.0 开始,Servlet最低版本为Servlet 5.0。

2.3 Spring MVC常见注解

(1)@Controller和@RestController

把某一个Java类申明为后端接口,我们一般使用@Controller修饰该类,使用@RestController也可以,两者的差异在于后者是@Controller和@ResponseBody的组合,后端接口返回的数据格式会是ResponseBody格式的数据。

大家看下两者的源码解释,南哥把英文注释翻译为了中文。

// 基本 Controller 接口,表示接收HttpServletRequest和HttpServletResponse实例的组件,就像HttpServlet一样,但能够参与 MVC 工作流。
@FunctionalInterface
public interface Controller {
   
   
}
// 便捷注释本身带有@Controller和@ResponseBody注释。
// 带有此注释的类型被视为控制器,其中@RequestMapping方法默认采用@ResponseBody语义。
@Target(ElementType.TYPE)
@Retention(RetentionPolicy.RUNTIME)
@Documented
@Controller
@ResponseBody
public @interface RestController {
   
   
}

(2)@RequestMapping

这个注解的作用是把请求映射到控制器方法,例如getPerson方法,前端同学请求/persons/{id}就可以控制该方法执行。

@RestController
@RequestMapping("/persons")
class PersonController {
   
   

    @GetMapping("/{id}")
    public Person getPerson(@PathVariable Long id) {
   
   
        // ...
    }

    @PostMapping
    @ResponseStatus(HttpStatus.CREATED)
    public void add(@RequestBody Person person) {
   
   
        // ...
    }
}

HTTP方法有多种请求类型,Spring框架也提供了五种Mapping注解。

  • @GetMapping
  • @PostMapping
  • @PutMapping
  • @DeleteMapping
  • @PatchMapping

(3)@RequestParam和、@PathVariable

有个Spring MVC注解相关的小细节,当我们编写有入参的后端接口时,很多同学弄不清楚入参对应的注解要使用什么。

南哥整理了下,如果请求URL类似于localhost:8080/test/?id=6,使用的入参注解是@RequestParam。

  @PostMapping("/test")
  public CommonResult publishCourse(@RequestParam String id) {
   
   
  }

如果请求URL类似于localhost:8080/test/6,使用的入参注解是@PathVariable。

  @PostMapping("/test/{id}")
  public CommonResult publishCourse(@PathVariable String id) {
   
   
  }

戳这,《JavaProGuide》作为一份涵盖Java程序员所需掌握核心知识、面试重点的Java学习面试指南。

在这里插入图片描述

欢迎关注南哥的公众号:Java进阶指南针。我是南哥,南就南在Get到你的有趣评论➕点赞➕关注。

创作不易,不妨点赞、收藏、关注支持一下,各位的支持就是我创作的最大动力❤️

相关文章
|
2月前
|
JSON 前端开发 Java
spring mvc Rest风格
spring mvc Rest风格
25 0
|
16天前
|
JSON 前端开发 Java
Spring MVC返回JSON数据
综上所述,Spring MVC提供了灵活、强大的方式来支持返回JSON数据,从直接使用 `@ResponseBody`及 `@RestController`注解,到通过配置消息转换器和异常处理器,开发人员可以根据具体需求选择合适的实现方式。
41 4
|
16天前
|
XML 前端开发 Java
Spring MVC接收param参数(直接接收、注解接收、集合接收、实体接收)
Spring MVC提供了灵活多样的参数接收方式,可以满足各种不同场景下的需求。了解并熟练运用这些基本的参数接收技巧,可以使得Web应用的开发更加方便、高效。同时,也是提高代码的可读性和维护性的关键所在。在实际开发过程中,根据具体需求选择最合适的参数接收方式,能够有效提升开发效率和应用性能。
43 3
|
17天前
|
XML 前端开发 Java
Spring MVC接收param参数(直接接收、注解接收、集合接收、实体接收)
Spring MVC提供了灵活多样的参数接收方式,可以满足各种不同场景下的需求。了解并熟练运用这些基本的参数接收技巧,可以使得Web应用的开发更加方便、高效。同时,也是提高代码的可读性和维护性的关键所在。在实际开发过程中,根据具体需求选择最合适的参数接收方式,能够有效提升开发效率和应用性能。
40 2
|
21天前
|
前端开发 Java API
Spring Boot 中的 MVC 支持
### Spring Boot 注解摘要 - **@RestController** - **@RequestMapping** - **@PathVariable** - **@RequestParam** - **@RequestBody**
20 2
|
5天前
|
前端开发 Java Spring
Java 新手入门:Spring Boot 轻松整合 Spring 和 Spring MVC!
Java 新手入门:Spring Boot 轻松整合 Spring 和 Spring MVC!
17 0
|
20天前
|
JSON 前端开发 Java
Spring Boot中的MVC支持
本节课主要讲解了 Spring Boot 中对 MVC 的支持,分析了 @RestController、 @RequestMapping、@PathVariable、 @RequestParam 和 @RequestBody 四个注解的使用方式,由于 @RestController 中集成了 @ResponseBody 所以对返回 json 的注解不再赘述。以上四个注解是使用频率很高的注解,在所有的实际项目中基本都会遇到,要熟练掌握。
|
1月前
|
前端开发 Java Spring
Spring MVC中使用ModelAndView传递数据
Spring MVC中使用ModelAndView传递数据
|
2月前
|
安全 前端开发 Java
挑战5分钟内基于Springboot+SpringMVC+Mybatis-plus快速构建web后端三层架构
挑战5分钟内基于Springboot+SpringMVC+Mybatis-plus快速构建web后端三层架构
38 1
|
1月前
|
XML 前端开发 Java
Spring Boot与Spring MVC的区别和联系
Spring Boot与Spring MVC的区别和联系