准备工作
<dependencies>
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>3.8.1</version>
<scope>test</scope>
</dependency>
<!-- 导入spring-webmvc依赖包,会导入spring的核心包-->
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-webmvc</artifactId>
<version>5.3.1</version>
</dependency>
<!-- 这个是一个日志实现类,因为我们thymeleaf中有sl4j日志接口,我们需要一个日志实现类来实现它-->
<dependency>
<groupId>ch.qos.logback</groupId>
<artifactId>logback-classic</artifactId>
<version>1.2.3</version>
</dependency>
<!-- servletAPI-->
<dependency>
<groupId>javax.servlet</groupId>
<artifactId>javax.servlet-api</artifactId>
<version>3.1.0</version>
<scope>provided</scope>
</dependency>
<!-- spring5和Thymeleaf的整合包-->
<dependency>
<groupId>org.thymeleaf</groupId>
<artifactId>thymeleaf-spring5</artifactId>
<version>3.0.12.RELEASE</version>
</dependency>
</dependencies>
SpringMVC配置
配置web.xml
<servlet>
<!-- 配置DispacherSerlver的servlet名字-->
<servlet-name>SpringMVC</servlet-name>
<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
</servlet>
<servlet-mapping>
<!-- 用DispcherServlet的名字来与url路径模型对应-->
<servlet-name>SpringMVC</servlet-name>
<!-- url路径模型可以使用通配符,/会匹配所有请求(除了.jsp结尾的请求,/*能匹配但不需要,因为tomcat的web.xml中有个JspServlet来处理.jsp请求),*.do会匹配所有以.do为结尾的请求-->
<url-pattern>/</url-pattern>
</servlet-mapping>
- 关于项目中的web.xml和tomcat的web.xml,如果发生冲突,优先项目中的web.xml
创建SpringMVC的配置文件
- 在SpringMVC中的配置文件都是在DispacherServlet初始化的时候就已经加载好了,不需要我们之前在spring中那样,还要用类路径加载一次配置文件
- 但由于是DispacherServlet加载的SpringMVC的配置文件,所以它的默认的名称和位置是固定的
- 位置:WEB-INF下
- 名称:
<servlet-name>-servlet.xml , 所以当前的配置名就是SpringMVC-servlet.xml
- 在该位置下配置一个名称叫SpringMVC-servlet的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 https://www.springframework.org/schema/context/spring-context.xsd">
<!-- 扫描控制层组件-->
<context:component-scan base-package="com.zt.controller"/>
<!-- 配置Thymeleaf视图解析器 -->
<bean id="viewResolver"
class="org.thymeleaf.spring5.view.ThymeleafViewResolver">
<property name="order" value="1"/>
<property name="characterEncoding" value="UTF-8"/>
<property name="templateEngine">
<bean class="org.thymeleaf.spring5.SpringTemplateEngine">
<property name="templateResolver">
<bean
class="org.thymeleaf.spring5.templateresolver.SpringResourceTemplateResolver">
<!-- 视图前缀 -->
<property name="prefix" value="/WEB-INF/templates/"/>
<!-- 视图后缀 -->
<property name="suffix" value=".html"/>
<property name="templateMode" value="HTML5"/>
<property name="characterEncoding" value="UTF-8" />
</bean>
</property>
</bean>
</property>
</bean>
</beans>
thymeleaf的物理视图就是我们访问资源的真实路径,逻辑视图加上前后缀就是物理视图
- 后续配置 [5 SpringMVC视图]
- 功能测试
- 在WEB-INF包下是我们java的web应用的安全目录,客户端无法直接访问,只能通过服务器转发访问
- Unsupported class file major version 61 这错时因为jdk版本和spring版本不适配导致的,把spring版本改成5.3.18就好了
- 使用@RequestMapping(“/”) 用这个来匹配url,匹配项以斜线开头一般都是绝对路径,这个斜线表示了http://localhost:8080/tomcat程序上下文(用来区分tomcat中的各个web项目)/
- 我写了一个Controller
@Controller
public class HelloController {
@RequestMapping("/")
public String protal(){
//将逻辑视图返回
return "index";//会被视图解析器解析,加上前后缀,然后被thymeleaf渲染发送给浏览器
}
}
- 通过视图解析,它最后会返回我的/WEB-INF/templates/index.html页面
- 至于为什么方法返回值是字符串,因为我返回给视图解析器的是一个字符串的逻辑视图
- 然后我在这个index.html中使用thymeleaf语法
<a th:href="@{/hello}">这个是在绝对路径上加了上下文的</a>
<a href="/hello">这个是不加的</a>
- 这两条的区别是什么呢,我们都知道,在路径里以/开头一般都是会加上绝对路径
- 第一条使用th语法的路径是
http://localhost:8080/SpringMVC/hello
- 第二条路径是
http://localhost:8080/hello
- 使用th语法会加上tomcat的程序上下文,它才会显示正确的url
- 特殊情况,如果控制器方法没有返回值,它会将控制器方法的@RequestMapping中的路径作为逻辑视图返回
SpringMVC入门总结与扩展
总结SpringMVC流程
- 浏览器发送请求被前端控制器Dispacher接收
- Dispacher会在初始化的时加载SpringMVC的核心配置文件,当Dispacher接收到了请求后,他会根据配置文件来扫描注解并找到控制器组件
- 将请求地址和控制器中@RequestMapping注解的value值进行匹配,若匹配成功,该注解所标识的控制器方法就是处理请求的方法
- 处理请求的方法需要返回一个字符串类型的视图名称,该视图名称会被视图解析器解析,加上前后缀组成视图的路径,通过Thymeleaf对视图进行渲染,最终转发到视图所对应页面
扩展
- 通过DispacheServlet配置(weg.xml中)指定Spring-MVC配置文件的位置,不用在固定放在WEB-INF下了
- 设置DispacherServlet初始化时机(由于DispacherServlet初始化的操作非常多,将Dispacher初始化提前到服务器启动时,这样第一次请求就不会等太久了)
<servlet>
<!-- 配置DispacherSerlver的servlet名字-->
<servlet-name>SpringMVC</servlet-name>
<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
<!-- 配置指定SpringMVC配置文件路径-->
<init-param>
<param-name>contextConfigLocation</param-name>
<param-value>classpath:SpringMVC-servlet.xml</param-value>
</init-param>
<!-- 配置DispacherServlet的初始化时机到服务器启动时-->
<load-on-startup>1</load-on-startup>
</servlet>