使用SpringMVC
使用SpringMVC最简单的方法是在pom.xml
中加入spring-boot-starter-web
依赖,这样Spring Boot的AutoConfiguration模块将为我们自动进行SpringMVC的配置,创建好RequestMappingHandlerAdapter
、RequestMappingHandlerMapping
等,详情可以参考org.springframework.boot.autoconfigure.web.servlet.WebMvcAutoConfiguration
和DelegatingWebMvcConfiguration
的源码。
这个时候就可以定义如下这样一个控制器,当请求/hello/json
时将返回{"key1": "value1", "key2": "value2"}
这样一段JSON。当Classpath下存在jackson相关的Class时就会自动添加MappingJackson2HttpMessageConverter
这样一个HttpMessageConverter
。关于默认添加的HttpMessageConverter
可以参考WebMvcConfigurationSupport
的addDefaultHttpMessageConverters()
的源码说明。
@RestController
@RequestMapping("hello")
public class HelloController {
@GetMapping("json")
public Object jsonResult() {
Map<String, Object> map = new HashMap<>();
map.put("key1", "value1");
map.put("key2", "value2");
return map;
}
}
DispatcherServlet的自动注册将由org.springframework.boot.autoconfigure.web.servlet.DispatcherServletAutoConfiguration
配置,其默认启用了Servlet的异步支持。
添加自定义的HttpMessageConverter
添加自定义的HttpMessageConverter
比较方便的方法是通过org.springframework.boot.autoconfigure.http.HttpMessageConverters
定义,它可以在指定使用默认的HttpMessageConverter
的同时添加额外的HttpMessageConverter
。下面的代码中就指定了在使用默认的HttpMessageConverter
的同时添加了一个自定义的CustomHttpMessageConverter
。
@Configuration public class MvcConfiguration {
@Bean
public HttpMessageConverters httpMessageConverters() {
HttpMessageConverter<?> customHttpMessageConverter = new CustomHttpMessageConverter();
List<HttpMessageConverter<?>> additional = new ArrayList<>();
additional.add(customHttpMessageConverter);
HttpMessageConverters converters = new HttpMessageConverters(true, additional);
return converters;
}
}
HttpMessageConverters
有几个重载的构造方法,使用时可以参考对应的API文档选择合适的进行使用。
Spring Boot中拥有一个HttpMessageConvertersAutoConfiguration
类,其会在未定义HttpMessageConverters
类型的bean时,自动注册一个HttpMessageConverters
类型的bean,即会通过它来使用默认的HttpMessageConverter
。此外,其会在自动注册bean容器中定义的HttpMessageConverter
,所以使用默认配置时也可以把需要注册的HttpMessageConverter
定义为bean容器中的一个bean。HttpMessageConvertersAutoConfiguration
中拥有一个StringHttpMessageConverterConfiguration
类,会在bean容器中未定义StringHttpMessageConverter
类型的bean时自动定义一个,使用的字符集默认是UTF-8
,可以通过在application.properties
中通过spring.http.encoding.charset
指定。
Converter和Formatter注册
下面的代码来自于WebMvcAutoConfigurationAdapter
,从代码中可以看出Spring Boot会自动注册bean容器中定义的Converter和Formatter。
@Override
public void addFormatters(FormatterRegistry registry) {
for (Converter<?, ?> converter : getBeansOfType(Converter.class)) {
registry.addConverter(converter);
}
for (GenericConverter converter : getBeansOfType(GenericConverter.class)) {
registry.addConverter(converter);
}
for (Formatter<?> formatter : getBeansOfType(Formatter.class)) {
registry.addFormatter(formatter);
}
}
静态资源的处理
Spring Boot默认会把Classpath下的/META-INF/resources/
、/resources/
、/static/
和/public/
映射为静态资源路径。静态资源的相关配置由ResourceProperties
类定义,对应的配置属性前缀是spring.resources
。如果不想使用默认的静态资源位置,可以通过spring.resources.static-locations
属性进行自定义。如果不需要把那些路径映射为静态资源路径,则可以设置spring.resources.addMappings
的值为true
。静态资源默认会映射为/**
,即如果在/resources
下拥有一个index.html
文件,则可以通过/index.html
请求到。可以通过spring.mvc.static-path-pattern
指定静态资源映射的路径,下面代码就指定了静态资源的映射路径为/resources/**
,/**
对应的才是真实的静态资源的路径,所以此时如果需要请求/resources
路径下的index.html
文件,需要通过/resources/index.html
才能请求到。
spring.mvc.static-path-pattern=/resources/**
更多配置信息可以参考ResourceProperties
的源代码。
浏览器图标文件
Spring Boot默认会在配置的静态资源根路径下或者是Classpath根路径下寻找favicon.ico
文件。
Content Negotiation
Spring Boot默认是不支持后缀名匹配的,即请求/report.json
时是不会被映射到@GetMapping("/report")
的。可以通过如下方式指定支持后缀名匹配。
spring.mvc.contentnegotiation.favor-path-extension=true
关于Content Negotiation的可选配置都定义在WebMvcProperties$Contentnegotiation.class
中。可以通过spring.mvc.contentnegotiation.favor-parameter=true
指定支持通过查询参数指定请求类型,默认的查询请求类型查询参数是format
,需要自定义时可以通过spring.mvc.contentnegotiation.parameter-name
属性来指定。
更换内置Web容器
当引入了spring-boot-starter-web
后默认使用的Web容器是tomcat,Spring Boot也提供了一些其它的实现,比如jetty,当需要使用jetty实现时需要先把tomcat实现从spring-boot-starter-web
中排除,再添加spring-boot-starter-jetty
依赖。
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
<exclusions>
<!-- Exclude the Tomcat dependency -->
<exclusion>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-tomcat</artifactId>
</exclusion>
</exclusions>
</dependency>
<!-- Use Jetty instead -->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-jetty</artifactId>
</dependency>
不启动Web容器
默认情况下你添加了spring-boot-starter-web
后Spring Boot会自动帮你启动Web容器,如果不期望启动Web容器可以配置spring.main.web-application-type=none
。
内置容器可配置的属性
当使用内置的Web容器时可以针对内置容器进行一些自定义的配置,这些配置将由org.springframework.boot.autoconfigure.web.ServerProperties
进行接收。常用的自定义配置包括server.port
指定监听端口,server.servlet.contextPath
指定contextPath,还可以通过server.servlet.session.*
指定session相关的定义信息。下面的配置中定义了监听端口是8081,contextPath是/app
,DispatcherServlet匹配的映射路径是/web/*
,session的超时时间三30分钟,当指定session的超时时间时,如果不指定时间单位,默认单位是秒。
server.port=8081
server.servlet.context-path=/app
server.servlet.path=/web
server.servlet.session.timeout=30m
更多关于内置Web容器可配置的信息可以参考org.springframework.boot.autoconfigure.web.ServerProperties
的API或源码。
注册Servlet/Filter等
根据Servlet3的规范,Classpath下的@WebServlet
、@WebFilter
和@WebListener
标注的Class会被Web容器自动检测到,并进行注册。但是使用Spring Boot内置的Web容器时,它们是不会自动被检测到并被注册的。有两种方式可以在使用内置的Web容器时能够让它们进行自动注册。
定义为Spring bean
Spring Bean容器中的定义的Filter/Servlet和Listener会被自动注册,Filter会拦截所有请求,而Servlet的请求路径将是bean名称,然后需要以/
结尾,比如下面代码中定义的Servlet的请求路径是/hello/
。
@Component("hello")
public class HelloServlet extends HttpServlet {
/**
*
*/
private static final long serialVersionUID = 8345578389259773375L;
@Override
protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
PrintWriter writer = resp.getWriter();
writer.write("hello");
writer.flush();
}
}
如果上面的Servlet对应的bean名称是servlet/hello
,则其对应的请求路径为/servlet/hello/
。
需要注意的是当bean容器中只定义了一个Servlet时,该Servlet的映射路径不是bean名称,而是
/
。
通过@ServletComponentScan
扫描
第二种方式是还是在Class上标注@WebServlet
、@WebFilter
或@WebListener
注解,然后在某个@Configuration
Class上标注@ServletComponentScan
,可以通过它的value、basePackages或basePackageClasses三者之一来指定需要扫描的包,如果都不指定,默认会以标注的Class所在的包作为根包进行扫描。下面的代码中先是定义了一个Servlet,使用了@WebServlet
标注,并指定了映射的路径为/servlet/test
。然后在Application类上使用了@ServletComponentScan
标注。Spring Boot将会扫描到TestServlet类,并把它注册为一个Servlet。
@WebServlet("/servlet/test")
public class TestServlet extends HttpServlet {
/**
*
*/
private static final long serialVersionUID = -2499437569852564816L;
@Override
protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
PrintWriter writer = resp.getWriter();
writer.write("Hello Servlet.");
writer.flush();
}
}
@SpringBootApplication
@ServletComponentScan
public class Application {
public static void main(String[] args) {
SpringApplication app = new SpringApplication(Application.class);
app.setAddCommandLineProperties(false);
app.run(args);
}
}
如果需要使用@WebServlet
的方式定义Servlet,同时又希望可以访问到Spring bean,则可以同时把Servlet定义为Spring的一个bean。下面的代码中定义的Servlet可以通过/servlet/hello
访问,同时它是一个Spring bean,被注入了ApplicationContext
,在访问它时会输出所有定义的bean的名称。该Servlet同时也可以通过/hello/
访问到,因为作为一个HttpServlet类型的bean,它也会被注册为一个Servlet,映射路径为bean名称。
@Component("hello")
@WebServlet("/servlet/hello")
public class HelloServlet extends HttpServlet {
@Autowired
private ApplicationContext applicationContext;
/**
*
*/
private static final long serialVersionUID = 8345578389259773375L;
@Override
protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
PrintWriter writer = resp.getWriter();
writer.println("bean names: ");
for (String name : this.applicationContext.getBeanDefinitionNames()) {
writer.println(name);
}
writer.flush();
}
}
参考文档
(注:本文是基于Spring Boot 2.0.3所写)
相关推荐
在“SpringMVC学习(一)——SpringMVC入门小程序”中,我们首先会接触到SpringMVC的基本概念。这通常包括以下几个核心组件: 1. **DispatcherServlet**:这是SpringMVC的前端控制器,负责接收HTTP请求,并根据配置...
在本教程中,我们将深入探讨如何将Spring框架、MyBatis持久层框架和SpringMVC Web框架整合到一个项目中,以实现高效、模块化的Web应用程序开发。...此外,还可以考虑使用Spring Boot来进一步简化配置,提升开发效率。
本文将详细探讨一款基于Java和Spring Boot技术栈实现的样本库实验室管理系统——LIMS(Laboratory Information Management System)。LIMS系统通常用于科学实验室,它整合了样品管理、实验记录、数据分析等多个关键...
涵盖使用Spring Boot 进行Java EE 开发的绝大数应用场景,包含:Web 开发、数据访问、安全控制、批处理、异步消息、系统集成、开发与部署、应用监控、分布式系统开发等。 第一部分 点睛Spring 4.x 第1 章 Spring ...
**Spring MVC —— 第一个应用程序** Spring MVC 是 Spring 框架的一个模块,主要用于构建 Web 应用程序。它提供了一种模型-视图-控制器(MVC)架构,简化了开发过程,使得开发者可以专注于业务逻辑而不必过于关心...
如果承载的是WEB项目,使用Spring MVC作为MVC框架,那么工作流程和你上面描述的是完全一样的,因为这部分工作是Spring MVC做的而不是Spring Boot。 Spring Boot和Spring MVC都是基于Spring框架的衍生产品,但它们...
【SpringMVC精品资源——基于SpringMVC+Spring+MyBatis构建的Java博客系统】 在Java Web开发领域,SpringMVC、Spring和MyBatis是三个非常重要的框架,它们一起构建了强大的后端开发解决方案。SpringMVC作为Spring...
【SpringMVC精品资源——基于SpringMVC、Spring和Mybatis构建的教务查询系统】 在IT行业中,SpringMVC、Spring和Mybatis是Java Web开发中的三大核心框架,它们协同工作可以构建出高效、可维护的Web应用程序。本资源...
5. **SpringMVC视频教程**:Spring MVC框架的使用技巧。 6. **JPA视频教程**:Java Persistence API的介绍。 7. **SpringData视频**:Spring Data项目的使用指南。 8. **SSSP整合&分页视频**:Spring、Spring MVC、...
在实际开发中,SSM整合还可以进一步优化,例如使用Spring Boot简化配置,使用MyBatis Plus增强MyBatis的功能,或者使用Spring Data JPA替代MyBatis等。总的来说,SSM组合提供了强大的灵活性和扩展性,是Java Web开发...
6. **最佳实践**:在SSM项目中,推荐使用注解配置以减少XML配置文件的复杂性,使用Spring Boot简化启动和配置过程,以及使用Spring Data JPA或者MyBatis的PageHelper实现分页功能。此外,单元测试和持续集成也是提高...
本示例代码"hibernate5+spring4+springmvc+maven基本框架整合"就是一个典型的应用场景,它展示了如何将四个关键的技术组件——Hibernate 5、Spring 4、Spring MVC和Maven——集成到一个项目中。接下来,我们将深入...
【狂神说】Spring PDF学习总结...学习Spring不仅有助于理解IoC和AOP的概念,还能为使用Spring Boot和Spring Cloud开发微服务打下坚实的基础。深入理解和熟练运用Spring框架对于任何Java开发者来说都是非常重要的技能。
- **Spring Boot Actuator**:如果使用Spring Boot,可以通过Actuator集成监控RabbitMQ的连接状态和指标。 7. **异常处理和重试策略** - **死信队列**:当消息无法正确路由或消费者无法处理时,可以将其放入死信...
SSM框架是Java开发中广泛使用的三大开源框架——Spring、SpringMVC和Mybatis的集成,它们协同工作,为Web应用程序提供了一套高效且灵活的解决方案。本项目使用IntelliJ IDEA作为集成开发环境(IDE),同时结合Maven...
【SpringMVC精品资源——基于SpringBoot + Shiro + MyBatisPlus的权限管理框架】 在现代企业级应用开发中,Spring Boot、Shiro和MyBatisPlus是极为常见的技术组合,它们各自承担着关键的角色。Spring Boot简化了...
SSM是Spring、SpringMVC和MyBatis的组合,是Java Web开发的常用框架栈。这份"Spring学习笔记+学习源码.zip"资源包含了深入学习Spring及其相关技术的知识点,以及实践代码,对提升Spring技能将大有裨益。 首先,我们...
在本项目中,我们将探讨如何将流行的Java开发工具IntelliJ IDEA(简称IDEA)与两个重要的企业级框架——SpringMVC和Mybatis——进行整合,以构建一个完整的Web应用程序。这个过程对于初学者来说是至关重要的,因为它...
- 使用 Spring Boot 可以简化项目的初始化和配置过程。 - 使用 Swagger UI 来文档化和测试 REST API,增强可维护性。 - 遵循 SOLID 原则和 DRY(Don't Repeat Yourself)原则编写代码,保持代码的可读性和可扩展...