- 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
4.28 Kotlin支持
Kotlin是一种针对JVM(和其他平台)的静态类型语言,它允许编写简洁而优雅的代码,同时提供与Java编写的现有库的互操作性。
Spring Boot通过利用其他Spring项目(如Spring Framework,Spring Data和Reactor)的支持来提供Kotlin支持。 有关更多信息,请参阅Spring Framework Kotlin支持文档。
从Spring Boot和Kotlin开始的最简单方法是遵循这个全面的教程。 您可以通过start.spring.io创建新的Kotlin项目。 如果您需要支持,请随意加入Kotlin Slack的#spring频道或使用Stack Overflow上的spring和kotlin标签提问。
4.28.1 Requirements
Spring Boot支持Kotlin 1.2.x. 要使用Kotlin,org.jetbrains.kotlin:kotlin-stdlib和org.jetbrains.kotlin:kotlin-reflect必须存在于类路径中。 也可以使用kotlin-stdlib变体kotlin-stdlib-jdk7和kotlin-stdlib-jdk8。
由于Kotlin类默认为final,因此您可能需要配置kotlin-spring插件以自动打开Spring-annotated类,以便可以代理它们。
在Kotlin中序列化/反序列化JSON数据需要Jackson的Kotlin模块。 在类路径中找到它时会自动注册。 如果Jackson和Kotlin存在但Jackson Kotlin模块不存在,则会记录警告消息。
如果在start.spring.io上引导Kotlin项目,则默认提供这些依赖项和插件。
4.28.2 Null-safety
Kotlin的一个关键特性是null安全。 它在编译时处理空值,而不是将问题推迟到运行时并遇到NullPointerException。 这有助于消除常见的错误来源,而无需支付像Optional这样的包装器的成本。 Kotlin还允许使用具有可空值的功能构造,如本Kotlin中关于null安全性的综合指南中所述。
虽然Java不允许在其类型系统中表示null安全性,但Spring Framework,Spring Data和Reactor现在通过易于使用工具的注释提供其API的安全性。 默认情况下,Kotlin中使用的Java API类型被识别为放宽空检查的平台类型。 Kotlin对JSR 305注释的支持与可空性注释相结合,为Kotlin中的相关Spring API提供了空安全性。
可以通过使用以下选项添加-Xjsr305编译器标志来配置JSR 305检查:-Xjsr305 = {strict | warn | ignore}。 默认行为与-Xjsr305 = warn相同。 在从Spring API推断出的Kotlin类型中需要考虑null安全性的严格值,但是应该使用Spring API可空性声明甚至可以在次要版本之间发展并且将来可能添加更多检查的知识。
尚不支持泛型类型参数,varargs和数组元素可空性。 有关最新信息,请参见SPR-15942。 另请注意,Spring Boot自己的API尚未注释。
4.28.3 Kotlin API
4.28.3.1 运行应用程序
Spring Boot提供了一种使用runApplication(*args)运行应用程序的惯用方法,如以下示例所示:
import org.springframework.boot.autoconfigure.SpringBootApplication
import org.springframework.boot.runApplication
@SpringBootApplication
class MyApplication
fun main(args: Array<String>) {
runApplication<MyApplication>(*args)
}
这是SpringApplication.run(MyApplication::class.java,*args)的替代品。 它还允许自定义应用程序,如以下示例所示:
runApplication<MyApplication>(*args) {
setBannerMode(OFF)
}
4.28.3.2 扩展
Kotlin扩展提供了使用附加功能扩展现有类的能力。 Spring Boot Kotlin API利用这些扩展为现有API添加新的Kotlin特定便利。
提供了类似于Spring Framework中的Spring Framework for RestOperations提供的TestRestTemplate扩展。 除此之外,扩展使得可以利用Kotlin reified类型参数。
4.28.4 依赖管理
为了避免在类路径上混合不同版本的Kotlin依赖项,提供了以下Kotlin依赖项的依赖项管理:
- kotlin-reflect
- kotlin-runtime
- kotlin-stdlib
- kotlin-stdlib-jdk7
- kotlin-stdlib-jdk8
- kotlin-stdlib-jre7
- kotlin-stdlib-jre8
使用Maven,可以通过kotlin.version属性自定义Kotlin版本,并为kotlin-maven-plugin提供插件管理。 使用Gradle,Spring Boot插件会自动将kotlin.version与Kotlin插件的版本对齐。
4.28.5 @ConfigurationProperties
@ConfigurationProperties目前仅适用于lateinit或nullable var属性(建议使用前者),因为尚不支持由构造函数初始化的不可变类。
@ConfigurationProperties("example.kotlin")
class KotlinExampleProperties {
lateinit var name: String
lateinit var description: String
val myService = MyService()
class MyService {
lateinit var apiToken: String
lateinit var uri: URI
}
}
要使用注释处理器生成您自己的元数据,应使用spring-boot-configuration-processordependency配置kapt。
4.28.6 测试
虽然可以使用JUnit 4(spring-boot-starter-test提供的默认值)来测试Kotlin代码,但建议使用JUnit 5。 JUnit 5允许测试类实例化一次,并重用于所有类的测试。 这使得可以在非静态方法上使用@BeforeAll和@AfterAll注释,这非常适合Kotlin。
要使用JUnit 5,请从spring-boot-starter-test中排除junit:junit依赖项,添加JUnit 5依赖项,并相应地配置Maven或Gradle插件。 有关更多详细信息,请参阅JUnit 5文档。 您还需要将测试实例生命周期切换为“per-class”。
为了模拟Kotlin类,建议使用Mockk。 如果需要Mockk等效的Mockito特定的@MockBean和@SpyBean注释,则可以使用SpringMockK,它提供类似的@MockkBean和@SpykBean注释。
4.28.7 资源
4.28.7.1 进一步阅读
- Kotlin语言参考
- Kotlin Slack(带有专用的#spring频道)
- Stackoverflow与spring和kotlin标签
- 在浏览器中试用Kotlin
- Kotlin博客
- 很棒的Kotlin
- 教程:使用Spring Boot和Kotlin构建Web应用程序
- 使用Kotlin开发Spring Boot应用程序
- 带有Kotlin,Spring Boot和PostgreSQL的地理空间信使
- 在Spring Framework 5.0中引入Kotlin支持
- Spring Framework 5 Kotlin API,函数式
4.28.7.2 示例
- spring-boot-kotlin-demo:常规Spring Boot + Spring Data JPA项目
- mixit:Spring Boot 2 + WebFlux + Reactive Spring Data MongoDB
- spring-kotlin-fullstack:WebFlux Kotlin fullstack示例,其中Kotlin2js用于前端而不是JavaScript或TypeScript
- spring-petclinic-kotlin:Spring PetClinic简单应用的Kotlin版本
- spring-kotlin-deepdive:将Boot 1.0 + Java逐步迁移到Boot 2.0 + Kotlin
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论