SpringMVC
1.特点
基于Spring原生Servlet,提供功能强大的前端控制器DispatcherServlet,对请求和响应进行统一处理
对表述层(表示层)需要解决的问题进行全方位覆盖,提供全面的解决方案
内部组件化程度高,可插拔式组件即插即用
性能卓著,适合大型互联网项目要求
2.使用
2.1.导入依赖
<dependencies>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-webmvc</artifactId>
<version>5.3.1</version>
</dependency>
<dependency>
<groupId>ch.qos.logback</groupId>
<artifactId>logback-core</artifactId>
<version>1.2.3</version>
</dependency>
<dependency>
<groupId>javax.servlet</groupId>
<artifactId>javax.servlet-api</artifactId>
<version>3.1.0</version>
<scope>provided</scope>
</dependency>
<dependency>
<groupId>org.thymeleaf</groupId>
<artifactId>thymeleaf-spring5</artifactId>
<version>3.0.11.RELEASE</version>
</dependency>
</dependencies>

SpringMVC也会将spring核心库导入
2.2.添加web.xml文件

(1)默认配置方式
此配置作用下,springMVC的配置文件默认位于WEB-INF下,默认名称为<servlet-name>-servlet.xml,例如下面的springMVC配置文件对应位置即为DispatcherServlet-servlet.xml
配置DispatcherServlet
<servlet>
<servlet-name>DispatcherServlet</servlet-name>
<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
</servlet>
<servlet-mapping>
<servlet-name>DispatcherServlet</servlet-name>
<url-pattern>/</url-pattern>
</servlet-mapping>
/表示可以匹配除.jsp外所有的请求路径
(2)扩展配置方式
可通过init-param标签设置SpringMVC配置文件的配置和名称,通过load-on-startup标签设置SpringMVC前端控制器DispatcherServlet的初始化时间
<servlet>
<servlet-name>DispatcherServlet</servlet-name>
<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
<!--通过初始化参数配置springMVC配置文件的位置和名称-->
<init-param>
<param-name>contextConfigLocation</param-name>
<!--classpath表示从类路径查找配置文件,例如Maven工程中的src/main/resources-->
<param-value>classpath:springMVC.xml</param-value>
</init-param>
<!-- 将初始化时间提前到服务器启动时 -->
<load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>
<servlet-name>DispatcherServlet</servlet-name>
<url-pattern>/</url-pattern>
</servlet-mapping>
/*则能够匹配所有的请求,在使用过滤器时,如果需要对所有请求进行过滤,就需要使用/*的写法
2.3.创建请求控制器
由于前端控制器对浏览器发送的请求进行统一处理,但是具体请求有不同处理过程,因此需要创建处理具体请求的类,即请求控制器
请求控制器中每一个处理请求的方法称为控制器方法,因为SpringMVC的控制器由一个POJO(普通的Java类)担任,因此需要通过@Controller注解将其标识为一个控制层组件,交给Spring的IOC容器管理,此时SpringMVC才能够识别控制器的存在
@Controller
public class HelloController{
}

浙公网安备 33010602011771号