작성
·
612
·
수정됨
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";
}
}
코드가 실행되는 이유
빈 라이플 사이클 중 Setter와 Field 주입은 객체 생성 후 의존관계 주입으로 나뉘어져있으므로
logDemo메서드가 실행하면 Provider.getObject()가 나올떄까지 빈 생성을 지연시키다가 request요청을 받은후 Provider.getObject()로 객체를 생성하고
setRequestURL()로 의존관계를 주입하는사이클 맞을까요?
답변 1
3
안녕하세요. 김아현님
1. 위 코드가 에러가 나는 이유: myLogger.setRequestURL() 부분과는 관련이 없습니다. request 스코프의 빈은 고객의 요청이 와야 생성이 됩니다. 그런데 LogDemoController를 생성할 때 생성자로 아직 생성되지도 않은 myLogger 빈을 전달해야 하게 때문에 발생하는 오류입니다.
2번은 myLoggerProvider.getObject()를 호출하는 시점은 이미 고객의 요청이 들어오고 있는 상태이고 이때 해당 메서드를 호출하면 request 스코프의 빈을 받아서 주입할 수 있습니다. 여기서도 myLogger.setRequestURL() 부분은 관련이 있습니다.
빈 스코프 부분을 다시 복습해주세요^^
감사합니다.