- 1 Spring Boot文档
- 1.1 关于这篇文档
- 1.2 获取帮助
- 1.3 第一步
- 1.4 使用Spring Boot
- 1.5 了解Spring Boot功能
- 1.6 转向生产
- 1.7 深入问题
- 2 入门
- 2.1 Spring Boot介绍
- 2.2 系统要求
- 2.3 安装Spring Boot
- 2.4 开发您的第一个Spring Boot应用程序
- 2.5 接下来要阅读的内容
- 3 使用Spring Boot
- 3.1 构建系统
- 3.1.1 依赖管理
- 3.2 结构化您的代码
- 3.3 配置类
- 3.4 自动配置
- 3.5 Spring Beans和依赖注入
- 3.6 使用@SpringBootApplication注解
- 3.7 运行您的应用程序
- 3.8 开发者工具
- 3.9 打包用于生产中的应用
- 3.10 接下来要阅读的内容
- 4 Spring Boot功能
- 4.1 SpringApplication
- 4.2 外部配置
- 4.3 Profiles
- 4.4 日志
- 4.5 国际化
- 4.6 JSON
- 4.7 开发Web应用程序
- 4.8 安全
- 4.9 使用SQL数据库
- 4.10 使用NoSQL技术
- 4.11 缓存
- 4.12 消息
- 4.13 使用RestTemplate调用REST服务
- 4.14 使用WebClient调用REST服务
- 4.15 校验
- 4.16 发送邮件
- 4.17 使用JTA的分布式事务
- 4.18 Hazelcast
- 4.19 Quartz Scheduler
- 4.20 任务执行和调度
- 4.21 Spring Integration
- 4.22 Spring Session
- 4.23 JMX的监控和管理
- 4.23 测试
- 4.25 WebSockets
- 4.26 Web Service
- 4.27 创建自己的自动配置
- 4.28 Kotlin支持
- 4.29 接下来要阅读的内容
- 5 Spring Boot Actuator: 生产就绪功能
- 5.1 启用生产就绪功能
- 5.2 Endpoints
- 5.3 通过HTTP进行监控和管理
- 5.4 JMX的监控和管理
- 5.5 Loggers
- 5.6 Metrics
- 5.7 审计
- 5.8 HTTP跟踪
- 5.9 进程监控
- 5.10 Cloud Foundry支持
- 5.11 接下来要阅读的内容
- 6 部署Spring Boot应用程序
- 6.1 部署到Cloud
- 6.2 安装Spring Boot应用程序
- 6.3 接下来要阅读的内容
- 7 Spring Boot CLI
- 7.1 安装CLI
- 7.2 使用CLI
- 7.3 使用Groovy Bean DSL开发应用程序
- 7.4 使用settings.xml配置CLI
- 7.5 接下来要阅读的内容
- 8 构建工具插件
- 8.1 Spring Boot Maven插件
- 8.2 Spring Boot Gradle插件
- 8.3 Spring Boot AntLib模块
- 8.4 支持其他构建系统
- 8.5 接下来要阅读的内容
- 9 ‘How-to’ 指南
- 9.1 Spring Boot应用
- 9.2 属性和配置
- 9.3 嵌入式Web服务器
- 9.4 Spring MVC
9.4 Spring MVC
Spring Boot有许多包含Spring MVC的启动器。 请注意,一些启动器包含对Spring MVC的依赖,而不是直接包含它。 本节回答有关Spring MVC和Spring Boot的常见问题。
9.4.1 编写JSON REST服务
只要Jackson2在类路径中,Spring Boot应用程序中的任何Spring @RestController都应默认呈现JSON响应,如以下示例所示:
@RestController
public class MyController {
@RequestMapping("/thing")
public MyThing thing() {
return new MyThing();
}
}
只要MyThing可以被Jackson2序列化(对于普通的POJO或Groovy对象都是如此),那么localhost:8080/thing默认提供它的JSON表示。 请注意,在浏览器中,您有时可能会看到XML响应,因为浏览器倾向于发送更喜欢XML的接受标头。
9.4.2 编写XML REST服务
如果在类路径上有Jackson XML扩展(jackson-dataformat-xml),则可以使用它来呈现XML响应。 我们用于JSON的前一个示例可以使用。 要使用Jackson XML渲染器,请将以下依赖项添加到项目中:
<dependency>
<groupId>com.fasterxml.jackson.dataformat</groupId>
<artifactId>jackson-dataformat-xml</artifactId>
</dependency>
如果Jackson的XML扩展不可用,则使用JAXB(默认情况下在JDK中提供),并且需要将MyThing注释为@XmlRootElement,如以下示例所示:
@XmlRootElement
public class MyThing {
private String name;
// .. getters and setters
}
要使服务器呈现XML而不是JSON,您可能必须发送Accept:text/xml标头(或使用浏览器)。
9.4.3 自定义Jackson ObjectMapper
Spring MVC(客户端和服务器端)使用HttpMessageConverters在HTTP交换中协商内容转换。 如果Jackson在类路径上,您已经获得了Jackson2ObjectMapperBuilder提供的默认转换器,其中一个实例是为您自动配置的。
ObjectMapper(或Jackson XML转换器的XmlMapper)实例(默认创建)具有以下自定义属性:
- MapperFeature.DEFAULT_VIEW_INCLUSION已禁用
- DeserializationFeature.FAIL_ON_UNKNOWN_PROPERTIES已禁用
- SerializationFeature.WRITE_DATES_AS_TIMESTAMPS已禁用
Spring Boot还具有一些功能,可以更轻松地自定义此行为。
您可以使用环境配置ObjectMapper和XmlMapper实例。 Jackson提供了一套广泛的简单开/关功能,可用于配置其处理的各个方面。 这些功能在六个enum(在Jackson中)中描述,它们映射到环境中的属性:
Enum | Property | Values |
---|---|---|
com.fasterxml.jackson.databind.DeserializationFeature | spring.jackson.deserialization. | true, false |
com.fasterxml.jackson.core.JsonGenerator.Feature | spring.jackson.generator.<feature_name> | true, false |
com.fasterxml.jackson.databind.MapperFeature | spring.jackson.mapper.<feature_name> | true, false |
com.fasterxml.jackson.core.JsonParser.Feature | spring.jackson.parser.<feature_name> | true, false |
com.fasterxml.jackson.databind.SerializationFeature | spring.jackson.serialization.<feature_name> | true, false |
com.fasterxml.jackson.annotation.JsonInclude.Include | spring.jackson.default-property-inclusion | always, non_null, non_absent, non_default, non_empty |
例如,要启用格式化打印,请设置spring.jackson.serialization.indent_output = true。 请注意,由于使用了宽松绑定,indent_output的情况不必与相应的枚举常量(即INDENT_OUTPUT)的情况相匹配。
此基于环境的配置应用于自动配置的Jackson2ObjectMapperBuilder bean,并应用于使用构建器创建的任何映射器,包括自动配置的ObjectMapper bean。
上下文的Jackson2ObjectMapperBuilder可以由一个或多个Jackso
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论