SpringMVC概述
web层的任务分析
由上图可以看出,有一个UserServlet负责去操作User对象的一些行为,然而在实际开发中肯定不止这一种servlet,还有什么比如productServlet啊之类的(根据具体业务具体分析),每一个servlet的内部所执行的操作、行为,有很多都是一致重复的,比如一般情况下每个servlet都会有的操作:接受请求参数、封装实体、访问业务层、接收返回结果,然后指派页面等。那既然这些操作都是一样的,那我们就可以把它们抽取出来,抽取出来之后通过使用一个框架让它来帮我们完成这些一样的操作,然后再让web层的组件比如UserServlet或者其他的servlet再去完成它们自己所特有的一些操作,这样是不是很方便呢?而抽取这些共性的操作一般就是web层的框架来帮我们封装完成的,下面这图可以大概让我们知道是个什么意思。
SpringMVC的开发步骤(快速入门)
那么SpringMVC的开发步骤是什么呢?下面的图完善了上面的图,其中每一个数字后面所对应的操作都对应了每一步开发的作用。
文字总结:
需求:客户端发起请求,服务器端接收请求,执行逻辑并进行视图跳转。
开发步骤:
1、导入SpringMVC相关坐标
2、配置SpringMVC核心控制器DispatcherServlet
3、创建Controller类和视图界面
4、使用注解配置Controller类中业务方法的映射地址
5、配置SpringMVC核心文件spring-mvc.xml
6、客户端发起请求测试
代码演示
第一步,先引入SpringMVC的相关坐标,主要是引入spring-webmvc,这个是前端控制器需要的jar包
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<parent>
<artifactId>SpringLearning</artifactId>
<groupId>com.Why</groupId>
<version>1.0-SNAPSHOT</version>
</parent>
<modelVersion>4.0.0</modelVersion>
<artifactId>SpringMVCLearning</artifactId>
<dependencies>
<!--引入Spring-->
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-context</artifactId>
<version>5.3.1</version>
</dependency>
<!--引入数据源c3p0-->
<dependency>
<groupId>c3p0</groupId>
<artifactId>c3p0</artifactId>
<version>0.9.1.2</version>
</dependency>
<!--引入mysql-->
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>8.0.23</version>
</dependency>
<!--引入spring中的web环境-->
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-web</artifactId>
<version>5.3.1</version>
</dependency>
<!--这个和spring-web可不一样
这个包是mvc框架要使用的,没有这个就没有前端控制器了
而上面的spring-web是spring集成web环境用的
spring-web提供了核心HTTP集成,包括一些便捷的
servlet过滤器,SpringHTTP调用,
用于集成其他web框架的基础结构以及技术;
而spring-webmvc是SpringMVC的一个实现
有了spring-webmvc就可以不显式的写上spring-web了
因为spring-webmvc依赖于spring-web,这样导入它就会间接
地添加spring-web,不必显式添加spring-web
如果不使用SpringMVC,但想要借助其他spring支持的web相关技术
的优势,那么我们就只需要依赖spring-web
还有一点补充,其实spring-webmvc内部也集成了spring-context
也就是说,有了spring-webmvc,连spring-context也是可以不用写的
-->
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-webmvc</artifactId>
<version>5.3.1</version>
</dependency>
<dependency>
<groupId>javax.servlet</groupId>
<artifactId>javax.servlet-api</artifactId>
<version>3.0.1</version>
<scope>provided</scope>
</dependency>
<!--servlet.jsp包的作用:
web项目里面开发jsp页面的时候,使用action调用servlet里面get和post方法的时候需要这个jar包
-->
<dependency>
<groupId>javax.servlet.jsp</groupId>
<artifactId>javax.servlet.jsp-api</artifactId>
<version>2.2.1</version>
<!--<scope>provided的作用是
防止Tomcat中也有相同的jar包而导致包冲突报错
provided表明该包只在编译和测试的时候用
(有没有都一样,反正不影响,知道什么用就行了,报错了再加这个也行)
-->
<scope>provided</scope>
</dependency>
</dependencies>
</project>
第二步,去web.xml配置文件中配置前端控制器
<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns="http://xmlns.jcp.org/xml/ns/javaee"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee http://xmlns.jcp.org/xml/ns/javaee/web-app_4_0.xsd"
version="4.0">
<!--配置SpringMVC的前端控制器-->
<servlet>
<servlet-name>DispatcherServlet</servlet-name>
<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
<!--对load-on-startup的说明
在servlet的配置当中,<load-on-startup>1</load-on-startup>的含义是:
标记容器是否在启动的时候就加载这个servlet。
当值为0或者大于0时,表示容器在应用启动时就加载这个servlet;
当是一个负数时或者没有指定时,则指示容器在该servlet被选择时才加载。
正数的值越小,启动该servlet的优先级越高
-->
<load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>
<servlet-name>DispatcherServlet</servlet-name>
<url-pattern>/</url-pattern>
</servlet-mapping>
<!--全局初始化参数-->
<context-param>
<param-name>contextConfigLocation</param-name>
<param-value>classpath:applicationContext.xml</param-value>
</context-param>
<!--配置监听器-->
<listener>
<listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
</listener>
</web-app>
第三步,配置我们的控制器,在itheima包下创建一个UserController类
package com.itheima.controller;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
@Controller
public class UserController {
@RequestMapping("/quick")
public String save(){
System.out.println("Controller save running...");
return "success.jsp";
}
}
同时web层下面写上对应的跳转后的视图文件success.jsp
<%--
Created by IntelliJ IDEA.
User: 爱闹的蹦蹦
Date: 2021/8/29
Time: 11:24
To change this template use File | Settings | File Templates.
--%>
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
<title>Title</title>
</head>
<body>
<h1>
Success
</h1>
</body>
</html>
第四步,要告诉Spring我们配置了UserController类,所以需要进行包扫描,但是这个扫描我们应该交给SpringMVC处理,这是为了更好的语义化,让各个模块分工明确,让Spring进行包扫描当然也是可以的。不过最好让SpringMVC来做,所以现在我们要创建一个SpringMVC的核心配置文件叫spring-mvc.xml,同样放在resources根目录下,采用Spring类型的配置文件(因为SpringMVC也是Spring体系中的一员)。
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:context="http://www.springframework.org/schema/context"
xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd
http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context.xsd">
<!--组件扫描:扫描mvc该知道的注解类,也就是controller类
同时包扫描要用到context命名空间,所以还要在头文件中加上命名空间
-->
<context:component-scan base-package="com.itheima.controller"></context:component-scan>
</beans>
同时这个配置文件上给谁用的呢,谁需要使用这个SpringMVC的配置文件?或者应该说是什么时候这个配置文件需要被加载呢?我们可以思考Spring的配置文件是在什么时候被加载的,哪儿呢?其实就是web项目下的web.xml中,当web项目一启动时,我们之前配置的监听器监听到web项目启动就会自动在web.xml文件当中去寻找Spring的核心配置文件并加载。同样的,web项目启动且前端控制器被使用时,我们的SpringMVC的配置文件就该起作用了,所以我们在前端控制器中配置上SpringMVC的配置文件。
<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns="http://xmlns.jcp.org/xml/ns/javaee"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee http://xmlns.jcp.org/xml/ns/javaee/web-app_4_0.xsd"
version="4.0">
<!--配置SpringMVC的前端控制器-->
<servlet>
<servlet-name>DispatcherServlet</servlet-name>
<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
<!--spring-mvc.xml文件是谁要用呢,很明显是前端控制器需要使用
所以我们要在前端控制器这里放上spring-mvc.xml的配置文件地址
以表示在web项目启动且前端控制器开始生效时,就需要加载spring-mvc的配置文件
-->
<init-param>
<param-name>contextConfigLocation</param-name>
<param-value>classpath:spring-mvc.xml</param-value>
</init-param>
<!--对load-on-startup的说明
在servlet的配置当中,<load-on-startup>1</load-on-startup>的含义是:
标记容器是否在启动的时候就加载这个servlet。
当值为0或者大于0时,表示容器在应用启动时就加载这个servlet;
当是一个负数时或者没有指定时,则指示容器在该servlet被选择时才加载。
正数的值越小,启动该servlet的优先级越高
-->
<load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>
<servlet-name>DispatcherServlet</servlet-name>
<url-pattern>/</url-pattern>
</servlet-mapping>
<!--全局初始化参数-->
<context-param>
<param-name>contextConfigLocation</param-name>
<param-value>classpath:applicationContext.xml</param-value>
</context-param>
<!--配置监听器-->
<listener>
<listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
</listener>
</web-app>
最后配置好Tomcat,就可以运行项目了。
小结
从代码角度访问的一个过程图示:
然后从宏观上的一个图示:
其中web应用中的Service部分就是前端控制器中Servlet内部的业务方法。