SpringMVC使用介绍-快速入门

SpringMVC

SpringMVC快速入门

SpringMVC是一种基于Java实现MVC模型的轻量级Web框架

优点

使用简单,开发便捷(相比于Servlet)

灵活性强

使用SpringMVC技术开发web程序流程:

1.创建web工程(Maven结构)

2.设置tomcat服务器,加载web工程(tomcat插件)

3.导入坐标(SpringMVC+Servlet)

4.定义处理请求的功能类(UserController)

5.设置请求映射(配置映射关系)

6.将SpringMVC设定加载到Tomcat容器中

入门案例知识储备:

@Controller, 类注解

作用:将SpringMVC的核心控制器定义为bean

@Controller
public class UserController {
    
      
}

@RequestMapping, 方法注解

作用:定义在SpringMVC控制器方法上方, 设置当前控制器方法请求访问路径

@RequestMapping("/save")
public void save(){
    
    
  System.out.println("user save ...");
}

@ResponseBody, 方法注解

作用: 定义在SpringMVC控制器方法上方, 设置当前控制器方法响应内容为当前返回值,无需解析

@RequestMapping("/save")
@ResponseBody
public String save(){
    
    
  	System.out.println("user save ...");
  	return "{'info':'springmvc'}";
}

SpringMVC案例实现:

目录结构

在这里插入图片描述

导入SpringMVC坐标与Servlet坐标(导入spring-webmvc坐标自动依赖spring相关坐标)

<dependencies>
  <!--servlet坐标-->
  <dependency>
    <groupId>javax.servlet</groupId>
    <artifactId>javax.servlet-api</artifactId>
    <version>3.1.0</version>
    <scope>provided</scope>
  </dependency>

  <!--SpringMVC坐标-->
  <dependency>
    <groupId>org.springframework</groupId>
    <artifactId>spring-webmvc</artifactId>
    <version>5.2.10.RELEASE</version>
  </dependency>
</dependencies>

初始化SpringMVC环境(同Spring环境): 创建一个控制器类(等同于Servlet功能)

// 定义controller
@Controller // 定义为bean
public class UserController {
    
    
    @RequestMapping("/save") // 设置当前操作的访问路径
    @ResponseBody // 设置响应内容为当前返回值类型
    public String save() {
    
     // 提供给外部一个方法处理请求
        System.out.println("user save...");
        return "{'module':'SpringMVC'}"; // 返回一个JSON字符串
    }
}

设定SpringMVC的配置文件, 加载我们定义的controller这个bean

@Configuration
@ComponentScan("com.chenyq.controller")
public class SpringMvcConfig {
    
    
}

定义一个servlet容器启动的配置类, 在里面加载spring的配置为了让Tomcat服务器在启动时加载SpringMVC配置类; 配置类继承AbstractDispatcherServletInitializer并重写方法

public class ServletContainersInitConfig extends AbstractDispatcherServletInitializer {
    
    
    // 加载springMVC容器配置的方法
    @Override
    protected WebApplicationContext createServletApplicationContext() {
    
    
        AnnotationConfigWebApplicationContext ctx = new AnnotationConfigWebApplicationContext();
        ctx.register(SpringMvcConfig.class);
        return ctx ;
    }

    // 设置哪些请求归属是springMVC处理的方法
    @Override
    protected String[] getServletMappings() {
    
    
        // 固定格式, 表示设置所有请求都归SpringMVC管理
        return new String[]{
    
    "/"};
    }

    // 加载spring容器配置的方法
    @Override
    protected WebApplicationContext createRootApplicationContext() {
    
    
        return null;
    }
}

启动Tomcat服务器访问/save能够显示数据就说明入门案例成功了

bean加载控制

Controller加载控制与业务bean加载控制:

SpringMVC控制表现层相关的bean

Spring控制业务层bean、数组层bean等

因为功能不同,我们需要避免Spring错误的加载到SpringMVC的bean

解决方案: 加载Spring控制的bean的时候, 排除掉SpringMVC控制的bean

SpringMVC相关bean加载控制

SpringMVC加载的bean对应的包均在com.chenyq.controller包内, 我们让SpringMVC只扫描com.chenyq.controller这个包即可

Spring相关bean加载控制

方式一:Spring加载的bean设定扫描范围为com.chenyq,但是要排除掉controller包内的bean

  • excludeFilters:排除扫描路径中加载的bean,需要指定类别(type)与具体项 (classes)
  • includeFilters:加载指定的bean,需要指定类别(type)与具体项(classes)
@Configuration
@ComponentScan(
    value = "com.chenyq",
    excludeFilters = @ComponentScan.Filter(
    type = FilterType.ANNOTATION,
        classes = Controller.class
    )
)
public class SpringConfig {
    
    
}

方式二:Spring加载的bean设定扫描范围为精准范围,例如: com.service包、com.dao包等

@Configuration
@ComponentScan({
    
    "com.chenyq.service", "com.chenyq.dao"})
public class SpringConfig {
    
    
}

方式三:不区分Spring与SpringMVC的环境,加载到同一个环境中

// ServletContainersInitConfig.class

public class ServletContainersInitConfig extends AbstractDispatcherServletInitializer {
    
    
    // 加载springMVC容器配置的方法
    @Override
    protected WebApplicationContext createServletApplicationContext() {
    
    
        AnnotationConfigWebApplicationContext ctx = new AnnotationConfigWebApplicationContext();
        ctx.register(SpringMvcConfig.class);
        return ctx ;
    }

    // 加载spring容器配置的方法
    @Override
    protected WebApplicationContext createRootApplicationContext() {
    
    
        AnnotationConfigWebApplicationContext ctx = new AnnotationConfigWebApplicationContext();
        ctx.register(SpringConfig.class);
        return ctx ;
    }

    // 设置哪些请求归属是springMVC处理的方法
    @Override
    protected String[] getServletMappings() {
    
    
        // 设置所有请求都归SpringMVC管理
        return new String[]{
    
    "/"};
    }
}

简化代码: 继承AbstractAnnotationConfigDispatcherServletInitializer类

public class ServletContainersInitConfig extends AbstractAnnotationConfigDispatcherServletInitializer {
    
    
    protected Class<?>[] getRootConfigClasses() {
    
    
        return new Class[]{
    
    SpringConfig .class};
    }

    protected Class<?>[] getServletConfigClasses() {
    
    
        return new Class[]{
    
    SpringMvcConfig.class};
    }

    protected String[] getServletMappings() {
    
    
        return new String[]{
    
    "/"};
    }
}

猜你喜欢

转载自blog.csdn.net/m0_71485750/article/details/128006729