目录
一、SpringMVC介绍
二、SpringMVC作用
三、SpringMVC核心组件
四、SpringMVC快速体验
一、SpringMVC介绍
Spring Web MVC是基于Servlet API构建的原始Web框架,从一开始就包含在Spring Framework中。正式名称“Spring Web MVC”来自其源模块的名称( spring-webmvc
),但它通常被称为“Spring MVC”。
在控制层框架历经Strust、WebWork、Strust2等诸多产品的历代更迭之后,目前业界普遍选择了SpringMVC作为Java EE项目表述层开发的首选方案。之所以能做到这一点,是因为SpringMVC具备如下显著优势:
- Spring 家族原生产品,与IOC容器等基础设施无缝对接
- 表述层各细分领域需要解决的问题全方位覆盖,提供全面解决方案
- 代码清新简洁,大幅度提升开发效率
- 内部组件化程度高,可插拔式组件即插即用,想要什么功能配置相应组件即可
- 性能卓著,尤其适合现代大型、超大型互联网项目要求
下面对比原生Servlet API 与SpringMVC开发
原生Servlet API
protected void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
String userName = request.getParameter("userName");
System.out.println("userName="+userName);
}
SpringMVC开发
@RequestMapping("/user/login")
public String login(@RequestParam("userName") String userName,Sting password){
log.debug("userName="+userName);
//调用业务即可
return "result";
}
对比可以看到,相比与原生的servlet,springmvc的功能更强大,可以自动给形参赋值。让程序员能够更专注于实现业务层的代码。
二、SpringMVC作用
SpringMvc与三层架构关系:
相比于MyBatis作用与Dao(持久层)层,SpringMVC是作用域表述层或者说控制层。负责处理用户发送请求与返回。
最主要的功能如下:
- 简化前端参数接收( 形参列表 )
- 简化后端数据响应(返回值)
- 以及其他......
三、SpringMVC核心组件
SpringMVC有多个核心组件,先认识一下几个组件DispatcherServlet、HandlerMapping、HandlerAdapter、ViewResolver。
pringMVC涉及组件理解:
- DispatcherServlet : SpringMVC提供,我们需要使用web.xml配置使其生效,它是整个流程处理的核心,所有请求都经过它的处理和分发![ CEO ]
- HandlerMapping : SpringMVC提供,我们需要进行IoC配置使其加入IoC容器方可生效,它内部缓存handler(controller方法)和handler访问路径数据,被DispatcherServlet调用,用于查找路径对应的handler![秘书]
- HandlerAdapter : SpringMVC提供,我们需要进行IoC配置使其加入IoC容器方可生效,它可以处理请求参数和处理响应数据数据,每次DispatcherServlet都是通过handlerAdapter间接调用handler,他是handler和DispatcherServlet之间的适配器![经理]
- Handler : handler又称处理器,他是Controller类内部的方法简称,是由我们自己定义,用来接收参数,向后调用业务,最终返回响应结果![打工人]
- ViewResovler : SpringMVC提供,我们需要进行IoC配置使其加入IoC容器方可生效!视图解析器主要作用简化模版视图页面查找的,但是需要注意,前后端分离项目,后端只返回JSON数据,不返回页面,那就不需要视图解析器!所以,视图解析器,相对其他的组件不是必须的![财务]
组件之间的关系如下图所示:
四、SpringMVC快速体验
1.配置需求
- DispatcherServlet,设置处理所有请求!
- HandlerMapping,HandlerAdapter,Handler需要加入到IoC容器,供DS调用!
- Handler自己声明(Controller)需要配置到HandlerMapping中供DS查找!
2.准备项目
springmvc-base-quick
注意:需要转成maven/web程序!!
温馨提示:如果项目创建出现问题,请查看构建工具maven是否是自己配置的版本,而不是idea自带的maven,因为idea自带的maven下载的包都是从国外的仓库进行下载。
idea2023版本设置javaWeb
其它版本设置Javaweb
3.导入依赖(servlet,ioc,mvc)
<properties>
<spring.version>6.0.6</spring.version>
<servlet.api>9.1.0</servlet.api>
<maven.compiler.source>17</maven.compiler.source>
<maven.compiler.target>17</maven.compiler.target>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
</properties>
<dependencies>
<!-- springioc相关依赖 -->
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-context</artifactId>
<version>${spring.version}</version>
</dependency>
<!-- web相关依赖 -->
<!-- 在 pom.xml 中引入 Jakarta EE Web API 的依赖 -->
<!--
在 Spring Web MVC 6 中,Servlet API 迁移到了 Jakarta EE API,因此在配置 DispatcherServlet 时需要使用
Jakarta EE 提供的相应类库和命名空间。错误信息 “‘org.springframework.web.servlet.DispatcherServlet’
is not assignable to ‘javax.servlet.Servlet,jakarta.servlet.Servlet’” 表明你使用了旧版本的
Servlet API,没有更新到 Jakarta EE 规范。
-->
<dependency>
<groupId>jakarta.platform</groupId>
<artifactId>jakarta.jakartaee-web-api</artifactId>
<version>${servlet.api}</version>
<scope>provided</scope>
</dependency>
<!-- springwebmvc相关依赖 -->
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-webmvc</artifactId>
<version>${spring.version}</version>
</dependency>
</dependencies>
4.创建Controller层包并创建HelloController类
@Controller
public class HelloController {
@RequestMapping("/springMvc")
@ResponseBody
public String Hello(){
System.out.println("HelloController.Hello");
return "hello,SpirngMvc";
}
5.使用配置类进行配置
@Configuration
@ComponentScan("com.alphamilk.Controller")
public class SpringMvcConfig {
// 将handlerMapping与handlerAdapter放入ioc容器
@Bean
public HandlerMapping handlerMapping(){
return new RequestMappingHandlerMapping();
}
@Bean
public HandlerAdapter handlerAdapter(){
return new RequestMappingHandlerAdapter();
}
}
6.配置springMvc初始化类
public class SpringmvcInit extends AbstractAnnotationConfigDispatcherServletInitializer {
@Override
protected Class<?>[] getRootConfigClasses() {
return null;
}
// 设置配置类
@Override
protected Class<?>[] getServletConfigClasses() {
return new Class[]{SpringMvcConfig.class};
}
// 设置dispatcherServlet的处理路径!
@Override
protected String[] getServletMappings() {
// 设置/代表处理所有路径
return new String[]{"/"};
}
}
7.配置tomcat本地服务器部署后并启动
注意: tomcat应该是10+版本!方可支持 Jakarta EE API!