inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

스프링 핵심 원리 - 기본편

스코프와 프록시

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

312

김형민

작성한 질문수 23

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

spring oop

답변 1

0

David

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

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

감사합니다.

SingletonService가 JVM이 뜰 때 생성되는게 맞나요?

0

60

2

섹션3. 11 회원객체 다이어그램

0

37

1

OCP, DIP과 @Qualifier 어노테이션에 대해서 질문합니다.

0

37

1

코드 자료

0

84

2

구현체가 동적으로 정해질 때, 팩토리 기법을 사용하나요?

0

83

2

MemberService의 인터페이스를 왜 사용하는지 궁금합니다.

0

99

1

롬복 @Setter를 써야 하는 상황이 있는건가요?

0

104

1

빈 등록 메서드의 파라미터가 빈이 아니어도 되나요?

0

89

1

테스트 속도가 나중에 영향이 있을까요?

0

91

1

gradle 설정 안떠서 질문 남깁니다!

0

145

2

build.gradle로 프로젝트를 여는 이유

0

100

1

provider 사용하는 이유

0

97

1

다음 강의 뭘 들어야 할까요

0

139

2

프로토타입 빈, 직접 destroy 호출 안 할 경우

0

70

1

beanB

0

92

2

퀴즈다시풀기

0

77

1

Gradle로 바꿔도 오류가 똑같이 발생하네요 ㅠㅠ

0

105

2

"중복 등록과 충돌" 강의에서 강사님과 다른 에러가 발생합니다.

0

71

3

run 실행했는데 결과창이 이렇게 뜨네요 왜 그런건가요>

0

116

2

도메인의 정의?

0

63

1

ApplicationContext 질문입니다.

0

68

1

@Scope의 proxyMode를 사용할때 단위 테스트 방법

0

98

2

ai api 선정하기 관련 질문

0

139

2

생성자 자동주입 관련해서

0

70

1