-
Notifications
You must be signed in to change notification settings - Fork 16
/
Copy pathContainer.kt
63 lines (54 loc) · 3.52 KB
/
Container.kt
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
package ioc
import io.kotest.core.spec.style.FreeSpec
import io.kotest.matchers.types.shouldBeTypeOf
import org.springframework.context.support.GenericGroovyApplicationContext
import org.springframework.context.support.GenericXmlApplicationContext
/**
* 컨테이너 개요
* 스프링 IoC 컨테이너에 대해 좀 더 알아봅시다.
*
* 스프링 애플리케이션은 ApplicationContext 인터페이스를 스프링 IoC 컨테이너로 사용합니다.
* 스프링 IoC 컨테이너를 줄여서 컨테이너(container)라고 부르기도 합니다.
* 컨테이너는 스프링이 아닌 다른 것(WAS 등)을 의미할 수 있으니 맥락에 따라 구분 해야 합니다.
*
* 애플리케이션 코드에서 ApplicationContext 인터페이스를 직접 사용하는 일은 거의 없습니다.
* 실제로 애플리케이션 코드는 getBean() 메서드 호출이 전혀 없어야 하며, Spring API에 대한 종속성도 없어야 합니다.
*
* ApplicationContext 인터페이스를 사용하는 코드를 보겠습니다.
*/
class Container : FreeSpec({
"""
컨테이너는 빈(Bean)을 등록하기 위해 구성 메타데이터(Configuration Metadata)를 사용합니다.
구성 메타데이터는 어떻게 빈(Bean)을 생성하고 구성할지에 대한 정보를 담고 있습니다.
이 정보는 XML 파일, Annotation, Java 코드로 작성할 수 있습니다.
구성 메타데이터를 통해 스프링 IoC 컨테이너는 객체를 생성하고, 객체 간의 의존성을 관리하며, 객체의 라이프 사이클을 관리합니다.
컨테이너 개요에서는 XML 기반 구성 메타데이터를 사용하는 방법을 살펴보겠습니다.
다른 형태의 Annotation, Java 코드 방식은 다른 챕터에서 다룹니다.
""" - {
"""
XML-based configuration metadata
스프링 초기부터 제공한 XML 구성 메타데이터 방식을 사용해봅시다.
XML 파일에 빈 설정을 기술합니다.
study/src/test/resources/ioc/applicationContext.xml 파일을 참고하세요.
""" {
val applicationContext = GenericXmlApplicationContext("classpath:ioc/applicationContext.xml")
// ApplicationContext에서 SampleObject Bean 객체를 조회합니다.
val sampleObject = applicationContext.getBean("sampleObject", SampleObject::class.java)
// 조회한 Bean 객체가 SampleObject 타입인지 확인합니다.
sampleObject.shouldBeTypeOf<Object>()
}
"""
Groovy 파일로 구성 메타데이터를 작성할 수도 있습니다.
스프링은 XML 파일 사용을 강제하지 않습니다. XML은 구성 메타데이터를 작성하는 여러 방법 중 하나일 뿐입니다.
XML, Groovy, Annotation, Java 코드 등등 구성 메타데이터를 작성할 수 있는 다양한 방법을 제공합니다.
개발자가 원한다면 커스텀한 방법으로 구성 메타데이터를 작성할 수 있습니다.
스프링은 특정 기술에 종속되지 않도록 설계되었습니다.
""" {
val applicationContext = GenericGroovyApplicationContext("classpath:ioc/applicationContext.groovy")
// ApplicationContext에서 SampleObject Bean 객체를 조회합니다.
val sampleObject = applicationContext.getBean("sampleObject", SampleObject::class.java)
// 조회한 Bean 객체가 SampleObject 타입인지 확인합니다.
sampleObject.shouldBeTypeOf<Object>()
}
}
})