SpringMVC入门

SpringMVC概述

替代了原来的Servlet

入门案例

SpringMVC环境搭建及测试

1.导入依赖

XML 复制代码
        <!--    SpringMVC-->
        <dependency>
            <groupId>javax.servlet</groupId>
            <artifactId>javax.servlet-api</artifactId>
            <version>4.0.1</version>
            <scope>provided</scope>
        </dependency>
        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-webmvc</artifactId>
            <version>${spring.version}</version>
        </dependency>

2.写Controller

java 复制代码
@Controller
public class UserController {
    @RequestMapping("/save")
    @ResponseBody
    public String save(){
        System.out.println("user save...");
        return "{'info':'SpringMVC'}";
    }
}

3.配置SpringMVC的config,让他加载SpringMVC需要的bean

java 复制代码
@Configuration
@ComponentScan("com.example.controller")
public class SpringMVCConfig {
}

4.配置Servlet容器

java 复制代码
public class ServletConfig extends AbstractDispatcherServletInitializer {
    @Override
    //加载SpringMVC的容器
    protected WebApplicationContext createServletApplicationContext() {
        AnnotationConfigWebApplicationContext context = new AnnotationConfigWebApplicationContext();
        context.register(SpringMVCConfig.class);
        return context;
    }

    @Override
    //设置哪些请求归属于SpringMVC处理
    protected String[] getServletMappings() {
        return new String[]{"/"};
    }

    @Override
    //加载Spring容器配置  SpringMVC底层会用到Spring
    protected WebApplicationContext createRootApplicationContext() {
        return null;
    }
}

启动Tomcat服务器,访问/save路径

流程分析

bean加载控制

我的目录结构

Spring需要加载除controller外的所有包,SpringMVC需要加载controller包

SpringMVCConfig

SpringConfig

方式1

方式2

这里会出现的一个问题是,由于SpringMVCConfig也用@Configuration注解,尽管SpringConfig已经把Controller排除了,但是SpringConfig 在扫描com.example包时 会调用SpringMVCConfig(里面加载了Controller) 把Controller重新加载回来,这样调用Spring的上下文对象仍然能得到Controller的实例化对象。测试代码和结果如下:

解决方法:

1.把这两个config都移到com.example包的外面,这样他们两个就不会被重复加载了。

2.SpringConfig加载的时候过滤@Component注解

方式3

这种方式下不区分Spring和SpringMVC的环境(这句话的意思是我们不需要显式地用@Component去定义SpringMVC和Spring的bean了(或者都扫同一个包?),也就是Spring和SpringMVC整合起来了,SpringMVC会用到Spring的bean

ServletConfig

java 复制代码
public class ServletConfig extends AbstractDispatcherServletInitializer {
    @Override
    //加载SpringMVC的容器
    protected WebApplicationContext createServletApplicationContext() {
        AnnotationConfigWebApplicationContext context = new AnnotationConfigWebApplicationContext();//初始化web容器
        context.register(SpringMVCConfig.class);
        return context;
    }

    @Override
    //设置哪些请求归属于SpringMVC处理
    protected String[] getServletMappings() {
        return new String[]{"/"};
    }

    @Override
    //加载Spring容器配置  这里加载Spring,不区分Spring和SpringMVC环境
    protected WebApplicationContext createRootApplicationContext() {
        AnnotationConfigWebApplicationContext context = new AnnotationConfigWebApplicationContext();//初始化springIoC容器
        context.register(SpringConfig.class);
        return context;
    }
}

ServletConfig优化(继承这个长长的东西)

代码量更少了

java 复制代码
public class ServletConfig extends AbstractAnnotationConfigDispatcherServletInitializer {

    @Override
    //加载Spring容器配置
    protected Class<?>[] getRootConfigClasses() {
        return new Class[]{SpringConfig.class};
    }

    @Override
    //加载SpringMVC的容器
    protected Class<?>[] getServletConfigClasses() {
        return new Class[]{SpringMVCConfig.class};
    }

    @Override
    //设置所有请求都归属于SpringMVC处理
    protected String[] getServletMappings() {
        return new String[]{"/"};
    }
}
相关推荐
隐于花海,等待花开16 小时前
FIND_IN_SET 与 LIKE 函数:使用场景及性能对比
hive
夕除1 天前
javaweb--04
数据仓库·hive·hadoop
juniperhan2 天前
Flink 系列第4篇:Flink 时间系统与 Timer 定时器实战精讲
java·大数据·数据仓库·flink
juniperhan2 天前
link 系列第7篇:Flink 状态管理全解析(原理+类型+存储+实操)
大数据·数据仓库·flink
juniperhan2 天前
Flink 系列第6篇:Watermark 水印全解析(原理+实操+避坑)
大数据·数据仓库·flink
武子康2 天前
大数据-264 实时数仓-MySQL Binlog配置详解:从原理到实践|数据恢复与主从复制实战
大数据·hadoop·后端
武子康2 天前
大数据-265 实时数仓-Canal MySQL Binlog配置详解:从原理到实践|数据恢复与主从复制实战
大数据·hadoop·后端
晓纪同学3 天前
WPF-03 第一个WPF程序
大数据·hadoop·wpf
2501_933329553 天前
技术深度剖析:Infoseek 字节探索舆情处置系统的全链路架构与核心实现
大数据·数据仓库·人工智能·自然语言处理·架构
xiaoyaohou113 天前
024、大数据技术栈概览:Hadoop、Spark与Flink
大数据·hadoop·spark