搭建框架

创建 Maven 工程

1、添加 Web 模块

(1)打包方式为 war

(2)项目结构 -> 项目设置 -> Facet -> 添加 Web -> 添加 Web 部署描述符

(3)Maven 工程根目录\src\main\webapp\WEB-INF\web.xml

(4)编辑 Web 资源目录路径:Web 工程根目录\src\main\webapp

(5)创建工件

(6)部署 Tomcat

2、引入依赖

<dependencies>
    <!-- SpringMVC -->
    <dependency>
        <groupId>org.springframework</groupId>
        <artifactId>spring-webmvc</artifactId>
        <version>5.3.20</version>
    </dependency>

    <!-- 日志 -->
    <dependency>
        <groupId>ch.qos.logback</groupId>
        <artifactId>logback-classic</artifactId>
        <version>1.2.11</version>
        <scope>test</scope>
    </dependency>

    <!-- ServletAPI -->
    <dependency>
        <groupId>javax.servlet</groupId>
        <artifactId>javax.servlet-api</artifactId>
        <version>4.0.1</version>
        <scope>provided</scope>
    </dependency>

    <!-- Thymeleaf和Spring5整合包 -->
    <dependency>
        <groupId>org.thymeleaf</groupId>
        <artifactId>thymeleaf-spring5</artifactId>
        <version>3.0.15.RELEASE</version>
    </dependency>
</dependencies>

3、配置 web.xml(存在先后顺序)

(1)编码过滤器

<!-- 配置编码过滤器 -->
<filter>
    <filter-name>CharacterEncodingFilter</filter-name>
    <filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class>
    <!-- post 请求编码 -->
    <init-param>
        <param-name>encoding</param-name>
        <param-value>UTF-8</param-value>
    </init-param>
    <!-- 响应编码 -->
    <init-param>
        <param-name>forceResponseEncoding</param-name>
        <param-value>UTF-8</param-value>
    </init-param>
</filter>
<filter-mapping>
    <filter-name>CharacterEncodingFilter</filter-name>
    <!-- 匹配所有请求地址 -->
    <url-pattern>/*</url-pattern>
</filter-mapping>

(2)配置 HiddenHttpMethodFilter

<!-- 配置HiddenHttpMethodFilter -->
<filter>
    <filter-name>HiddenHttpMethodFilter</filter-name>
    <filter-class>org.springframework.web.filter.HiddenHttpMethodFilter</filter-class>
</filter>
<filter-mapping>
    <filter-name>HiddenHttpMethodFilter</filter-name>
    <url-pattern>/*</url-pattern>
</filter-mapping>

(3)注册 SpringMVC 前端控制器 DispatcherServlet

(4)默认配置方式:SpringMVC 配置文件默认位于 WEB-INF 目录,默认名称为 <servlet-name>-servlet.xml

<!-- 配置SpringMVC前端控制器,统一管理浏览器发送请求 -->
<servlet>
    <servlet-name>SpringMVC</servlet-name>
    <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
</servlet>
<servlet-mapping>
    <servlet-name>SpringMVC</servlet-name>
    <!--
        设置SpringMvc的核心控制器所能处理的请求的请求路径
        /匹配的请求可以是/login或.html或.js或.css方式的请求路径,但是/不能匹配.jsp请求路径的请求,可以避免在访问jsp页面时,该请求被DispatcherServlet处理,从而找不到相应的页面
        /*则能够匹配所有请求        
    -->
    <url-pattern>/</url-pattern>
</servlet-mapping>

(5)扩展配置方式(最优): 可通过 init-param 标签设置 SpringMVC 配置文件的位置和名称,通过 load-on-startup 标签设置 SpringMVC 前端控制器 Dispatcherservlet 的初始化时间

<!-- 配置SpringMVC前端控制器,统一管理浏览器发送请求 -->
<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.xml</param-value>
    </init-param>
    <!-- 将前端控制器DispatcherServlet的初始化时间,提前到服务器启动时 -->
    <load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>
    <servlet-name>SpringMVC</servlet-name>
    <!--
        设置SpringMvc的核心控制器所能处理的请求的请求路径
        /匹配的请求可以是/login或.html或.js或.css方式的请求路径,但是/不能匹配.jsp请求路径的请求,可以避免在访问jsp页面时,该请求被DispatcherServlet处理,从而找不到相应的页面
        /*则能够匹配所有请求      
    -->
    <url-pattern>/</url-pattern>
</servlet-mapping>

 

配置 springMVC.xml

1、路径:Maven 工程根目录\src\main\resources,

2、开启组件扫描

(1)注解方式

@ComponentScan(basePackages = {"包路径"})

(2)xml 方式

<?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">

    <!-- 开启注解(组件)扫描 -->
    <context:component-scan base-package="*"></context:component-scan>
    
</beans>

3、配置 Thymeleaf 视图解析器

<!-- 配置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>

 

配置 index.html

1、路径:Maven 工程根目录\src\main\webapp\WEB-INF\templates\index.html

2、开启 thymeleaf 命名空间:xmlns:th="http://www.thymeleaf.org"

<html lang="en" xmlns:th="http://www.thymeleaf.org">

 

创建请求控制器

1、前端控制器统一处理浏览器发送的请求,但是具体的请求有不同的处理过程,需要创建处理具体请求的类,即请求控制器

2、请求控制器中每一个处理请求的方法成为控制器方法

3、SpringMVC 控制器由一个 POJO 担任,通过 @Controller 注解将其标识为一个控制层组件,交给 Spring IOC 容器管理,使 SpringMVC 识别控制器

 

测试

1、在请求控制器中创建处理请求的方法,实现对首页的访问

@Controller
public class HomeController {

    //处理请求和控制器方法之间的映射关系,value通过请求地址匹配请求
    //由/表示当前上下文路径:localhost:8080/springMVC/
    @RequestMapping(value = "/")
    public String index() {
        //返回视图名称
        return "index";
    }
    
    @RequestMapping("/target")
    public String target(){
        return "target";
    }
}

 2、index.html 设置超链接跳转到指定页面

<!DOCTYPE html>
<html lang="en" xmlns:th="http://www.thymeleaf.org">
<head>
    <meta charset="UTF-8">
    <title>首页</title>
</head>
<body>
<h1>Home</h1>
<a th:href="@{/target}">目标页面</a>
</body>
</html>
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>
This is target
</body>
</html>

 

执行顺序

1、浏览器发送请求

(1)若请求地址符合前端控制器的 url-pattern,该请求就会被 DispatcherServlet 处理

2、DispatcherServlet 会读取 SpringMVC 核心配置文件,通过扫描组件找到控制器,将请求地址和控制器中 @RequestMapping 注解 value 属性值进行匹配

(1)若匹配成功,该注解所标识的控制器方法就是处理请求的方法

3、处理请求的方法需要返回一个字符串类型的视图名称,该视图名称会被视图解析器解析,加上前缀和后缀组成视图路径,通过 Thymeleaf 对视图进行渲染,最终转发到视图所对应页面

posted @   半条咸鱼  阅读(94)  评论(0编辑  收藏  举报
(评论功能已被禁用)
相关博文:
阅读排行:
· 微软正式发布.NET 10 Preview 1:开启下一代开发框架新篇章
· 没有源码,如何修改代码逻辑?
· PowerShell开发游戏 · 打蜜蜂
· 在鹅厂做java开发是什么体验
· WPF到Web的无缝过渡:英雄联盟客户端的OpenSilver迁移实战
点击右上角即可分享
微信分享提示