인프런 커뮤니티 질문&답변

최성규님의 프로필 이미지

작성한 질문수

스프링 핵심 원리 - 기본편

인터페이스 InitializingBean, DisposableBean

강의대로 실행이 안돼요.ㅜ

해결된 질문

작성

·

293

3

hello.core.lifecycle.NetworkClient.java

package hello.core.lifecycle;

import org.springframework.beans.factory.DisposableBean;
import org.springframework.beans.factory.InitializingBean;

public class NetworkClient implements InitializingBean, DisposableBean {

    private String url;

    public NetworkClient() {
        System.out.println("생성자 호출, url = " + url);
        /*connect();
        call("초기화 연결 메시지");*/
    }

    public void setUrl(String url) {
        this.url = url;
    }

    // 서비스 시작시 호출
    public void connect() {
        System.out.println("Connect: " + url);
    }

    public void call(String message) {
        System.out.println("call: " + url + ", message = " + message);
    }

    public void disconnect() {
        System.out.println("Close: " + url);
    }

    @Override
    public void afterPropertiesSet() throws Exception {
        /* 생성자에 있던 코드를 이곳으로 ---> "생성과 초기화를 분리" */
        System.out.println("NetworkClient.afterPropertiesSet");
        connect();
        call("초기화 연결 메시지");
    }

    @Override
    public void destroy() throws Exception {
        System.out.println("NetworkClient.destroy");
        System.out.println("destroy() : url = " + url);
        disconnect();
    }
}


hello.core.lifecycle.BeanLifeCycleTest.java

package hello.core.lifecycle;

import org.junit.jupiter.api.Test;
import org.springframework.context.ApplicationContext;
import org.springframework.context.ConfigurableApplicationContext;
import org.springframework.context.annotation.AnnotationConfigApplicationContext;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;

public class BeanLifeCycleTest {

    @Test
    public void lifeCycleTest() {
        ConfigurableApplicationContext ac = new AnnotationConfigApplicationContext(NetworkClient.class);
        NetworkClient client = ac.getBean(NetworkClient.class);
        ac.close();
    }

    @Configuration
    static class LifeCycleConfig {

        @Bean
        public NetworkClient networkClient() {
            NetworkClient networkClient = new NetworkClient();
            networkClient.setUrl("http://hello-spring.net");
            return networkClient;
        }
    }
}

제 코드의 실행 결과

생성자 호출, url = null
NetworkClient.afterPropertiesSet
Connect: null
call: null, message = 초기화 연결 메시지
01:08:27.660 [main] DEBUG org.springframework.context.annotation.AnnotationConfigApplicationContext - Closing org.springframework.context.annotation.AnnotationConfigApplicationContext@4a7f959b, started on Fri Dec 11 01:08:27 KST 2020
NetworkClient.destroy
destroy() : url = null
Close: null

답변 4

1

최성규님의 프로필 이미지
최성규
질문자

2020. 12. 11. 18:13

자답입니다. 오타를 찾아서 해결했습니다. 오타는 항상 어처구니가 없네요.

@Test public void lifeCycleTest() 메소드 첫 줄에 LifeCycleConfig.class 여야 하는데, NetworkClient.class 로 적은 부분입니다. 

영한님의 소중한 시간을 위해, 답변 달지 않으셔도 됩니다.

감사합니다.

0

하나님의 프로필 이미지

2022. 08. 16. 17:30

같은 실수때문에 고생하다가 해결하고 갑니다.

감사합니다

0

dev님의 프로필 이미지

2021. 04. 13. 09:15

저도 같은 실수를 해서 질문 남기러 왔다가 깨닫고 갑니다 :)

0

김영한님의 프로필 이미지
김영한
지식공유자

2020. 12. 11. 19:30

성규님 스스로 잘 해결하셨습니다^^

이렇게 하는 과정속에서 디버깅 하는 방법을 배울 수 있습니다. 그래서 저는 이런 과정도 중요하다 생각합니다.

화이팅!