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

김아현님의 프로필 이미지

작성한 질문수

스프링 핵심 원리 - 기본편

스코프와 Provider

수업 내용 이게 맞을까요?

작성

·

609

·

수정됨

1

@Controller
@RequiredArgsConstructor
public class LogDemoController {
    private final LogDemoService logDemoService;
    private final MyLogger myLogger;
    @RequestMapping("log-demo")
    @ResponseBody
    public String logDemo(HttpServletRequest request) {
        String requestURL = request.getRequestURL().toString();
        myLogger.setRequestURL(requestURL);
        myLogger.log("controller test");
        logDemoService.logic("testId");
        return "OK";
    }
}

1. 위 코드가 에러가 나는 이유

@RequiredArgsConstructor 이 코드로 생성자 자동 주입을 실행

빈 라이플 사이클 생성자 주입특징으로 객체 생성 과정과 의존관계주입이 한번에 일어나니

MyLogger 객체가 setRequestURL 세터 메서드로인해 (외부에서 입력 받아야하니) 정보를 못담아서 에러가 나는거 맞을까요?

 

    @RequestMapping("log-demo")
    @ResponseBody
    public String logDemo(HttpServletRequest request) {
        String requestURL = request.getRequestURL().toString();
        MyLogger myLogger = myLoggerProvider.getObject();
        myLogger.setRequestURL(requestURL);
        myLogger.log("controller test");
        logDemoService.logic("testId");
        return "OK";
    }
}
  1. 코드가 실행되는 이유

빈 라이플 사이클 중 Setter와 Field 주입은 객체 생성 후 의존관계 주입으로 나뉘어져있으므로

logDemo메서드가 실행하면 Provider.getObject()가 나올떄까지 빈 생성을 지연시키다가 request요청을 받은후 Provider.getObject()로 객체를 생성하고

setRequestURL()로 의존관계를 주입하는사이클 맞을까요?

답변 1

3

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

안녕하세요. 김아현님

1. 위 코드가 에러가 나는 이유: myLogger.setRequestURL() 부분과는 관련이 없습니다. request 스코프의 빈은 고객의 요청이 와야 생성이 됩니다. 그런데 LogDemoController를 생성할 때 생성자로 아직 생성되지도 않은 myLogger 빈을 전달해야 하게 때문에 발생하는 오류입니다.

2번은 myLoggerProvider.getObject()를 호출하는 시점은 이미 고객의 요청이 들어오고 있는 상태이고 이때 해당 메서드를 호출하면 request 스코프의 빈을 받아서 주입할 수 있습니다. 여기서도 myLogger.setRequestURL() 부분은 관련이 있습니다.

  1. 빈 스코프 부분을 다시 복습해주세요^^

감사합니다.