다양한 설정 형식 지원 - 자바코드, xml
스프링 설정정보를 java파일 이외에 xml, groovy 등등을 사용할 수 있다.
왜냐면
ApplicationContext(인터페이스) 구현체들로 다음과 같은 것들이 있기 때문이다.
AnnotationConfig AppliactionContext => AppConfig.class
GeneriXml ApplicationContext => appConfig.xml
Xxx ApplicationContext => appConfig.xxx =>다양한 설정형식을 지원한다.
XML 설정 사용해보기
요즘 잘 안쓰긴하지만 xml을 사용하면 컴파일 없이 빈 설정 정보를 변경할 수 잇다.
GenericXmlApplicationContext를 사용해서 xml 설정 파일을 넘기면 된다.
package hello.core.xml;
import hello.core.member.Member;
import hello.core.member.MemberService;
import hello.core.member.MemberServiceImpl;
import org.assertj.core.api.Assertions;
import org.junit.jupiter.api.Test;
import org.springframework.context.ApplicationContext;
import org.springframework.context.support.GenericApplicationContext;
import org.springframework.context.support.GenericXmlApplicationContext;
public class XmlAppContext {
@Test
void xmlAppContext(){
ApplicationContext ac = new GenericXmlApplicationContext("appConfig.xml");
MemberService memberService = ac.getBean("memberService", MemberService.class);
Assertions.assertThat(memberService).isInstanceOf(MemberService.class);
}
}
이제 appConfig.xml 파일 작성!
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans.xsd">
<bean id="memberService" class="hello.core.member.MemberServiceImpl" >
<constructor-arg name="memberRepository" ref="memberRepository" /> //생성자, 참조
</bean>
<bean id="memberRepository" class="hello.core.member.MemoryMemberRepository" />
<bean id="orderService" class="hello.core.order.OrderServiceImpl">
<constructor-arg name="memberRepository" ref="memberRepository" />
<constructor-arg name="discountPolicy" ref = "discountPolicy" />
</bean>
<bean id="discountPolicy" class="hello.core.discount.RateDiscountPolicy"/>
</beans>
AppConfig.java와 유사한것을 알 수 있다.
중요한 것은 스프링이 이렇게 다양한 설정 형식을 지원한다는 것이다.
과연 어떻게???
스프링 빈 설정 메타 정보 - BeanDefinition
BeanDefinition이라는 추상화가 있다.
위에서 말한것처럼, 역할과 구현을 개념적으로 나눈것!!!
BeanDefinition을 빈 설정 메타정보라 한다.
@Bean,
스프링 컨테이너 ------> BeanDefinition <-- AppConfig.class, AppConfig.xml, AppConfig.xxx
스프링 컨테이너는 BeanDefinition 인터페이스에만 의존한다.
따라서 BeanDefinition에는 뭐가 들어가는지 모른다. 그냥 그 역할을 수행하면 된다.
너무 깊게 이해할 필요는 없으니 필기한거 참고!
그냥 저렇게 추상화를 사용해서 다양한 설정형식을 지원한다고 알고 있으면된다.
package hello.core.beandefinition;
import hello.core.AppConfig;
import org.junit.jupiter.api.DisplayName;
import org.junit.jupiter.api.Test;
import org.springframework.beans.factory.config.BeanDefinition;
import org.springframework.context.annotation.AnnotationConfigApplicationContext;
public class BeanDefinitionTest {
//getBeanDefinition을 사용하기 위해서
//ApplicationContext 대신 사용
//getBeanDefinition은 왠만해선 쓸일 거의 없음 => 빈 설정 메타정보임
AnnotationConfigApplicationContext ac = new AnnotationConfigApplicationContext(AppConfig.class);
@Test
@DisplayName("빈 설정 메타 정보 확인")
void findApplicationBean(){
String[] beanDefinitionNames = ac.getBeanDefinitionNames();
for (String beanDefinitionName : beanDefinitionNames) {
BeanDefinition beanDefinition = ac.getBeanDefinition(beanDefinitionName);
if(beanDefinition.getRole() == BeanDefinition.ROLE_APPLICATION){
System.out.println("beanDefinition = " + beanDefinition + "beanDefinition =" +beanDefinition);
}
}
}
}
'공부 > Spring_2-스프링 핵심 원리 이해1' 카테고리의 다른 글
스프링 핵심 원리 이해1_7 -@Configuration과 싱글톤 (0) | 2022.04.07 |
---|---|
스프링 핵심 원리 이해1_6 - 싱글톤 컨테이너 (0) | 2022.04.07 |
스프링 핵심원리 이해1_4 - 스프링컨테이너 빈 조회 (0) | 2022.04.07 |
스프링 핵심원리 이해1_3 - 스프링으로 전환(AppConfig 기반) (0) | 2022.04.07 |
스프링 핵심원리 이해1_2 - 새로운 할인정책 개발, AppConfig (0) | 2022.04.07 |