【SpringMVC】一、SpringMVC概述与环境配置

SpringMVC概述

MVC

MVC是一种软件架构的思想,其将软件按照模型、视图、控制器来进行划分

  • M:Model模型层,指工程中的JavaBean,作用是处理数据,

    JavaBean分为两类,一类是实体类Bean,如User、Student,用来存储数据。

    另一类是业务处理Bean,指Service与Dao对象,专门用于处理业务逻辑和数据访问。

  • V:View层,视图层,指工程中的html或jsp页面,作用是与用户进行交互,展示数据。

  • C:Controller层,控制层,指工程中的Servlet,作用是接收请求和相应浏览器。

MVC思想的工作流程:用户通过视图层发送请求到服务器,在服务器中请求被Controller接收,Controller再调用相应的Model层请求,处理完毕并将结果返回到Controller层,Controller再根据请求处理的结果找到相应的View视图,渲染数据后传递给浏览器。

SpringMVC

SpringMVC是为表述层开发提供的一整套解决方案,表述层在经历了Struct、WebWork、Struct2等诸多产品,目前稳定在SpringMVC框架作为表述层开发的首选框架。

特点:

  • Spring 家族原生产品,与 IOC 容器等基础设施无缝对接
  • 基于原生的Servlet,通过了功能强大的前端控制器DispatcherServlet,对请求和响应进行统一处理
  • 表述层各细分领域需要解决的问题全方位覆盖,提供全面解决方案
  • 代码清新简洁,大幅度提升开发效率
  • 内部组件化程度高,可插拔式组件即插即用,想要什么功能配置相应组件即可
  • 性能卓著,尤其适合现代大型、超大型互联网项目要求

开发环境

添加依赖:

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

        <!-- 日志 -->
        <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>

并将其设置为web模块(即加入打包方式)

<packaging>war</packaging>

注意:spring-webmvc依赖下会有许多spring-framework的jar包,故其包括了spring的功能

ServletAPI的加入只是为了开发方便,实际项目中会使用Tomcat中集成的ServletAPI,不会使用依赖中的,故将其适用范围限定为provuded,这样就可以将这个jar包的作用范围限制到开发过程中(以避免jar包版本不一致导致的奇奇怪怪的问题)

文件目录

在main文件夹下新建webapp文件夹用于存放web

在这里插入图片描述

接着在projectstruct中添加web.xml文件,注意文件存放位置

在这里插入图片描述

创建完成后的文件目录如下:
在这里插入图片描述

web.xml配置与Teymeleaf测试

由于浏览器不能直接访问一个类,故要进行Servlet注册。

注册一个DispatcherServlet来统一管理,并进行SpringMVC配置,在servlet标签中配置init-param来配置springMVC.xml的位置,注意param-name标签不能更改

    <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>
<!--        '/' 代表响应除了jsp页面以外的所有请求-->
        <url-pattern>/</url-pattern>
    </servlet-mapping>

在springMVC.xml中开启组件扫描,并在Controller上添加@Controller注解。

注意:视图解析器中的视图前缀和视图后缀都是已经定义好的,我们直接写index就可以

    <!-- 配置Thymeleaf视图解析器 -->
    <bean id="viewResolver" class="org.thymeleaf.spring5.view.ThymeleafViewResolver">
<!--        Thymeleaf优先级的配置-->
        <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>

测试类:

//添加@Controller注解保证Spring对其进行IoC注入
@Controller
public class HelloController {

    //@RequestMapping注解可以将请求与方法绑定,当请求为'/时',就会执行下面的方法返回index
    //index又会被Thymeleaf渲染并添加视图前缀和视图后缀,使页面被固定到...index.html
    @RequestMapping(value = "/")
    public String index() {
        return "index";
    }
}

注意"/"代表上下文路径,也就是在tomcat中配置的路径

浏览器发送请求,由于@RequestMapping中配置的"/"所以该请求会由这个注解调用index()方法,这个方法又会返回index,再因为Servlet中的注册,这个方法会由Thymeleaf渲染视图前缀和试图后缀并进行访问,最终得到index.html的文件显示在浏览器中

在标签的属性前加th:该属性就会被thymeleaf解析,例如跳转:

index.html

<!DOCTYPE html>
<html lang="en" xmlns:th="http://www.thymeleaf.org">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>
    <h1>首页</h1>
<!--    要加入上下文路径/springMVC,才能通过绝对路径对其进行访问(上下文路径是Tomcat在进行配置时自定义设置的)-->
    <!-- 要使用@{}进行标注 -->
<a th:href=@{/target}>访问目标页面</a>
</body>
</html>

target.html

<!DOCTYPE html>
<html lang="en" xmlns:th="http://www.thymeleaf.org">
<head>
    <meta charset="UTF-8">
    <title>Target</title>
</head>
<body>
Hello World
</body>
</html>

加上跳转的Controller:

@Controller
public class HelloController {

    //@RequestMapping注解可以将请求与方法绑定,当请求为'/时',就会执行下面的方法返回index
    //index又会被Thymeleaf渲染并添加视图前缀和视图后缀,使页面被固定到...index.html
    @RequestMapping(value = "/")
    public String index() {
        return "index";
    }

//    拦截/traget请求(a标签中的定义)并调用如下方法,返回值会被thymeleaf渲染
    @RequestMapping(value = "/target")
    public String toTarget() {
        return "target";
    }
}

总结

浏览器发送请求,若请求地址符合前端控制器的url-pattern,该请求就会被前端控制器DispatcherServlet处理。前端控制器会读取SpringMVC的核心配置文件,通过扫描组件找到控制器,将请求地址和控制器中@RequestMapping注解的value属性值进行匹配,若匹配成功,该注解所标识的控制器方法就是处理请求的方法。处理请求的方法需要返回一个字符串类型的视图名称,该视图名称会被视图解析器解析,加上前缀和后缀组成视图的路径,通过Thymeleaf对视图进行渲染,最终转发到视图所对应页面

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值