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[]{"/"};
    }
}
相关推荐
计算机源码社1 天前
分享一个基于Hadoop的二手房销售签约数据分析与可视化系统,基于Python可视化的二手房销售数据分析平台
大数据·hadoop·python·数据分析·毕业设计项目·毕业设计源码·计算机毕设选题
计算机毕设残哥1 天前
完整技术栈分享:基于Hadoop+Spark的在线教育投融资大数据可视化分析系统
大数据·hadoop·python·信息可视化·spark·计算机毕设·计算机毕业设计
计算机源码社2 天前
分享一个基于Hadoop+spark的超市销售数据分析与可视化系统,超市顾客消费行为分析系统的设计与实现
大数据·hadoop·数据分析·spark·计算机毕业设计源码·计算机毕设选题·大数据选题推荐
beijingliushao2 天前
33-Hive SQL DML语法之查询数据-2
hive·hadoop·sql
Lx3522 天前
如何正确选择Hadoop数据压缩格式:Gzip vs LZO vs Snappy
大数据·hadoop
让头发掉下来2 天前
Hive 创建事务表的方法
大数据·hive·hadoop
Q_Q19632884752 天前
python基于Hadoop的超市数据分析系统
开发语言·hadoop·spring boot·python·django·flask·node.js
计算机毕业设计木哥2 天前
计算机毕设大数据选题推荐 基于spark+Hadoop+python的贵州茅台股票数据分析系统【源码+文档+调试】
大数据·hadoop·python·计算机网络·spark·课程设计
W.A委员会2 天前
SpringMVC
数据仓库·hive·hadoop·spring
王小王-1233 天前
基于Hadoop的全国农产品批发价格数据分析与可视化与价格预测研究
大数据·hive·hadoop·flume·hadoop农产品价格分析·农产品批发价格·农产品价格预测