반응형

다양한 설정 형식 지원 - 자바코드, 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);
            }
        }

    }
}

 

 

 

 

728x90
반응형
블로그 이미지

아상관없어

,