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>
<dependency>
<groupId>javax.servletgroupId>
<artifactId>javax.servlet-apiartifactId>
<version>3.1.0version>
<scope>providedscope>
dependency>
<dependency>
<groupId>org.springframeworkgroupId>
<artifactId>spring-webmvcartifactId>
<version>5.2.10.RELEASEversion>
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
能够显示数据就说明入门案例成功了
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[]{"/"};
}
}