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

김형민님의 프로필 이미지

작성한 질문수

스프링 핵심 원리 - 기본편

스코프와 프록시

프록시 사용 시 실제 MyLogger빈 주입 시점 질문입니다.

작성

·

241

1

정확히 어느 시점에 실제 MyLogger빈을 찾아서 넣어주는 지 보려고 콘솔에 찍어봤는데 setRequestURL()과 logic()을 호출하여도 가짜 프록시 객체가 myLogger에 들어있는 데 제가 뭔가 잘못 이해한 것 인가요?

코드

String requsetURL = request.getRequestURL().toString(); //고객이 어떤 url로 요청했는지 알 수 있음
System.out.println("myLogger = " + myLogger.getClass()); //이때는 가짜 객체 들어가 있음(프록시에 의해서)

myLogger.setRequestURL(requsetURL);
System.out.println("myLogger = " + myLogger.getClass());
myLogger.log("controller test");
System.out.println("myLogger = " + myLogger.getClass());
logDemoService.logic("testId");

 

결과

myLogger = class hello.core.common.MyLogger$$EnhancerBySpringCGLIB$$ab757f1f

[cd224578-38c2-4e3c-9326-ef6d0be4491d] request scope message bean create:hello.core.common.MyLogger@2210fc0f

myLogger = class hello.core.common.MyLogger$$EnhancerBySpringCGLIB$$ab757f1f

[cd224578-38c2-4e3c-9326-ef6d0be4491d][http://localhost:8080/log-demo]controller test

myLogger = class hello.core.common.MyLogger$$EnhancerBySpringCGLIB$$ab757f1f

[cd224578-38c2-4e3c-9326-ef6d0be4491d][http://localhost:8080/log-demo]service id = testId

[cd224578-38c2-4e3c-9326-ef6d0be4491d] request scope message bean close:hello.core.common.MyLogger@2210fc0f

답변 1

0

안녕하세요. 김형민님, 공식 서포터즈 David입니다.

실제 MyLogger를 찾는 부분을 확인하시려면 프록시 객체 내부에서 target을 호출하는 쪽을 디버깅해보셔야 합니다.  애플리케이션 실행시 프록시 객체가 주입되고, 실제 요청이 들어왔을 때 프록시 객체는 진짜 객체를 컨테이너로부터 찾아와(없으면 생성) 수행해야 하는 로직을 위임하게 됩니다. 아래 빨간 박스 내용이 핵심입니다.

감사합니다.