Spring Boot 프로젝트에 데이터 클래스 추가하기
이 튜토리얼은 Spring Boot와 Kotlin 시작하기의 두 번째 파트입니다. 계속하기 전에 이전 단계를 완료했는지 확인하십시오.
Kotlin으로 Spring Boot 프로젝트 생성
Spring Boot 프로젝트에 데이터 클래스 추가
Spring Boot 프로젝트에 데이터베이스 지원 추가
Spring Data CrudRepository를 사용하여 데이터베이스 액세스
이 튜토리얼의 이 파트에서는 애플리케이션에 몇 가지 기능을 더 추가하고 데이터 클래스와 같은 Kotlin 언어 기능을 더 자세히 알아봅니다.
MessageController
클래스를 변경하여 직렬화된 객체의 컬렉션을 포함하는 JSON 문서를 응답해야 합니다.
애플리케이션 업데이트
-
동일한 패키지에서 두 개의 속성
id
및text
가 있는 데이터 클래스를 사용하여Message.kt
파일을 만듭니다.// Message.kt
package demo
data class Message(val id: String?, val text: String)Message
클래스는 데이터 전송에 사용됩니다. 직렬화된Message
객체 목록은 컨트롤러가 브라우저 요청에 응답할 JSON 문서를 구성합니다.데이터 클래스 – data class Message
Kotlin의 데이터 클래스(data classes)의 주요 목적은 데이터를 보유하는 것입니다. 이러한 클래스는 data
키워드로 표시되며 일부 표준 기능과 일부 유틸리티 함수는 종종 클래스 구조에서 기계적으로 파생될 수 있습니다.
이 예제에서는 Message
의 주요 목적이 데이터를 저장하는 것이므로 데이터 클래스로 선언했습니다.
val 및 var 속성
Kotlin의 속성(Properties in Kotlin) 클래스는 다음 중 하나로 선언할 수 있습니다.
var
키워드를 사용하는 mutableval
키워드를 사용하는 read-onlyMessage
클래스는 val
키워드를 사용하여 id
및 text
라는 두 개의 속성을 선언합니다.
컴파일러는 이러한 속성 모두에 대해 getter를 자동으로 생성합니다.
Message
클래스의 인스턴스가 생성된 후에는 이러한 속성의 값을 다시 할당할 수 없습니다.
Nullable 유형 – String?
Kotlin은 nullable 유형에 대한 기본 제공 지원을 제공합니다. Kotlin에서 유형 시스템은 null
을 포함할 수 있는 참조(nullable 참조)와 포함할 수 없는 참조(non-nullable 참조)를 구별합니다.
예를 들어 String
유형의 일반 변수는 null
을 포함할 수 없습니다. null을 허용하려면 변수를 String?
로 작성하여 nullable 문자열로 선언할 수 있습니다.
Message
클래스의 id
속성은 이번에는 nullable 유형으로 선언됩니다.
따라서 id
에 대한 값으로 null
을 전달하여 Message
클래스의 인스턴스를 만들 수 있습니다.
Message(null, "Hello!")
-
MessageController.kt
파일에서index()
함수 대신Message
객체 목록을 반환하는listMessages()
함수를 만듭니다.// MessageController.kt
package demo
import org.springframework.web.bind.annotation.GetMapping
import org.springframework.web.bind.annotation.RequestMapping
import org.springframework.web.bind.annotation.RestController
@RestController
@RequestMapping("/")
class MessageController {
@GetMapping
fun listMessages() = listOf(
Message("1", "Hello!"),
Message("2", "Bonjour!"),
Message("3", "Privet!"),
)
}
컬렉션 – listOf()
Kotlin 표준 라이브러리는 기본 컬렉션 유형(세트, 목록 및 맵)에 대한 구현을 제공합니다.
한 쌍의 인터페이스는 각 컬렉션 유형을 나타냅니다.
해당 팩토리 함수는 Kotlin 표준 라이브러리에서 이러한 컬렉션의 인스턴스를 만들기 위해 제공됩니다.
이 튜토리얼에서는 listOf()
함수를 사용하여 Message
객체 목록을 만듭니다.
이것은 객체의 read-only 목록을 만드는 팩토리 함수입니다. 목록에서 요소를 추가하거나 제거할 수 없습니다.
목록에서 쓰기 작업을 수행해야 하는 경우 mutableListOf()
함수를 호출하여 mutable 목록 인스턴스를 만듭니다.
후행 쉼표
후행 쉼표(trailing comma)는 일련의 요소의 마지막 항목 뒤에 있는 쉼표 기호입니다.
Message("3", "Privet!"),
이것은 Kotlin 구문의 편리한 기능이며 완전히 선택 사항입니다. 코드는 후행 쉼표 없이도 계속 작동합니다.
위의 예에서 Message
객체 목록을 만드는 데는 마지막 listOf()
함수 인수 뒤에 후행 쉼표가 포함됩니다.
MessageController
의 응답은 이제 Message
객체의 컬렉션을 포함하는 JSON 문서가 됩니다.
Jackson 라이브러리가 클래스 경로에 있는 경우 Spring 애플리케이션의 모든 컨트롤러는 기본적으로 JSON 응답을 렌더링합니다.
build.gradle.kts
파일에서 spring-boot-starter-web
종속성을 지정했으므로 Jackson을 transitive 종속성으로 받았습니다.
따라서 엔드포인트가 JSON으로 직렬화될 수 있는 데이터 구조를 반환하는 경우 애플리케이션은 JSON 문서를 응답합니다.
다음은 DemoApplication.kt
, MessageController.kt
및 Message.kt
파일의 전체 코드입니다.
// DemoApplication.kt
package demo
import org.springframework.boot.autoconfigure.SpringBootApplication
import org.springframework.boot.runApplication
@SpringBootApplication
class DemoApplication
fun main(args: Array<String>) {
runApplication<DemoApplication>(*args)
}
// MessageController.kt
package demo
import org.springframework.web.bind.annotation.GetMapping
import org.springframework.web.bind.annotation.RequestMapping
import org.springframework.web.bind.annotation.RestController
@RestController
@RequestMapping("/")
class MessageController {
@GetMapping
fun listMessages() = listOf(
Message("1", "Hello!"),
Message("2", "Bonjour!"),
Message("3", "Privet!"),
)
}
// Message.kt
package demo
data class Message(val id: String?, val text: String)
애플리케이션 실행
Spring 애플리케이션을 실행할 준비가 되었습니다.
-
애플리케이션을 다시 실행합니다.
-
애플리케이션이 시작되면 다음 URL을 엽니다.
http://localhost:8080
JSON 형식의 메시지 컬렉션이 있는 페이지가 표시됩니다.
다음 단계
튜토리얼의 다음 파트에서는 프로젝트에 데이터베이스를 추가 및 구성하고 HTTP 요청을 합니다.