inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

스프링 핵심 원리 - 고급편

private method 포함한 Controller @Aspect로 AOP 적용했을때의 의문점

878

hes

작성한 질문수 1

3

안녕하세요. Controller에 AOP를 적용하는 과정에서 궁금한점이 있어 질문을 올립니다.
보통 handler method 는 private 으로 지정하진 않겠지만, 만일 private으로 지정해도 handler는 정상 동작하는 것으로 알고 있고 정상 동작도 확인하였습니다.
 
그런데, @Aspect 이용해서 해당 Controller의 Proxy를 빈으로 등록시켰을때 문제가 발생합니다.
 
우선, 첫번째 예상했던 것은 CGLIB는 상속을 이용하기에 private메서드는 상속을 못해서 handler가 정상동작하지 못할 것 같았습니다.
하지만 결과는 정상동작하는 것을 보았습니다. 어떻게 정상동작이 수행가능 한걸까요?
혹시, private handler의 경우는 바로 target메서드를 찾아 실행시키나 해서 stack trace를 봐보면 Enhancer객체에서 실행되는 것을 볼 수 있습니다.
 
 
물론, 이처럼 간단한 handler라면, 정상적으로 응답이 오지만 만일 해당 handler가 의존성주입된 객체를 사용하려고 한다면 Enhancer 객체는 상태를 갖지않는 proxy객체라 NullPointerException이 발생합니다.
 
 
 
의문점을 정리해보자면,
`private handler는 어떻게 Enhancer객체에서 수행할 수 있을까? ` 입니다.
 
한번 reflection은 private메서드도 수행가능하기에 상속한 슈퍼클래스의 private 메서드를 이용해 정상 동작한다. 로 가정하고 생각해봤습니다. 그러면 또 꼬리의문이 드는데 슈퍼클래스의 private메서드를 이용한다면, 실제 target 메서드이므로 DI된 객체가 null이 되는 것이 의문 입니다.
 

spring 디자인-패턴

답변 1

0

김영한

안녕하세요. hes님

이 부분은 저도 잘 모르겠습니다. 혹시 아시는 분 있으면 답변 남겨주세요.

감사합니다.

SpringBoot 4.0.6 버전에서 PackageLogTracePostProcessor exception

0

39

2

어드바이스 순서 디폴트 기준이 궁금합니다.

0

67

1

AspectV1 예제를 @Configuration 수동 등록으로도 가능한가요?

0

96

2

구체 클래스를 상속받아 확장한 형태도 클래스패턴/데코레이터 패턴이라고 칭하나요?

0

67

1

TraceTemplate 을 미리 빈으로 등록해서 사용할때 이렇게 설정하는게 맞는건가요?

0

60

1

Decorator 에서 추상메서드로 뺄때 질문 있습니다.

0

59

1

대상 클래스에 기본 생성자가 없을 때

0

80

1

스프링 부트 버전 4.0 aop 의존성 명칭 변경

1

392

2

final 키워드 사용 관련 질문

0

82

1

안녕하세요

0

72

1

ThradLocal 실무 사례

0

103

2

실무에서의 동시성 문제

0

70

1

로그 등 부가 기능에 대한 테스트코드

0

56

1

ProceedingJoinPoint와 MethodInvocation에 대하여

0

73

1

실무 멀티스레딩에 대한 궁금증

0

75

1

안녕하세요 질문있습니다

0

47

1

AspectV3 aop 실행 순서 문의 드립니다

0

43

1

MDC vs AOP 중에 고민중입니다.

0

82

1

순환참조

0

165

2

this를 단독으로 사용할때랑 파라미터 바인딩 할때 차이

0

83

1

빈 후처리에 등록 질문 있습니다.

0

84

1

AppConfig 설정하는 설명중에 이해가 안되는게 있습니다.

0

97

1

ThreadLocal을 지역변수로 선언하면 remove가 필요할까요?

0

121

2

@Aspect 어노테이션으로 생성된 Advisor의 Bean 저장 여부

0

75

1