작성
·
1.7K
0
학습하는 분들께 도움이 되고, 더 좋은 답변을 드릴 수 있도록 질문전에 다음을 꼭 확인해주세요.
1. 강의 내용과 관련된 질문을 남겨주세요.
2. 인프런의 질문 게시판과 자주 하는 질문(링크)을 먼저 확인해주세요.
(자주 하는 질문 링크: https://bit.ly/3fX6ygx)
3. 질문 잘하기 메뉴얼(링크)을 먼저 읽어주세요.
(질문 잘하기 메뉴얼 링크: https://bit.ly/2UfeqCG)
질문 시에는 위 내용은 삭제하고 다음 내용을 남겨주세요.
=========================================
[질문 템플릿]
1. 강의 내용과 관련된 질문인가요? (예/아니오)
2. 인프런의 질문 게시판과 자주 하는 질문에 없는 내용인가요? (예/아니오)
3. 질문 잘하기 메뉴얼을 읽어보셨나요? (예/아니오)
[질문 내용]
"package hello.hellospring.aop;
import org.aspectj.lang.ProceedingJoinPoint;
import org.aspectj.lang.annotation.Around;
import org.aspectj.lang.annotation.Aspect;
import org.springframework.stereotype.Component;
@Component
@Aspect
public class TimeTraceAop {
@Around("execution(* hello.helloSpring..*(..))")
public Object execute(ProceedingJoinPoint joinPoint) throws Throwable {
long start = System.currentTimeMillis();
System.out.println("START : " + joinPoint.toString());
try {
return joinPoint.proceed();
} finally {
long finish = System.currentTimeMillis();
long timeMs = finish - start;
System.out.println("END : " + joinPoint.toString()+ " " + timeMs + "ms");
}
}
}" TimeTraceAop 클래스를 작성한 이후에 실행을 시켜보아도 수업처럼 START END 부분이실행되지 않습니다.
단순 스프링 실행화면만 보이는데 어디가 문제일까요?
답변 3
1
Spring AOP 는 상속 기반으로 구현되어 있기 때문에 혹시 AOP를 적용 하시려는 메소드가 private 이라면 AOP 가 적용되지 않을 수 있습니다! 이 부분도 확인해 보시면 좋을 것 같아요
1
안녕하세요, 인프런 AI 인턴이에요.
AOP가 적용되지 않는 문제에 대해서 도움을 드리겠습니다.
먼저, AOP가 적용되지 않는 이유는 다양할 수 있습니다.
Aspect가 스프링 빈으로 등록되지 않았을 수 있습니다. TimeTraceAop 클래스에 @Component 어노테이션을 추가하여 스프링 빈으로 등록되었는지 확인해주세요.
AOP 포인트컷 설정이 올바르게 되어 있는지 확인해야 합니다. TimeTraceAop 클래스의 @Around 어노테이션 내부의 포인트컷 표현식(execution(* hello.helloSpring..*(..)))이 올바른지 확인해주세요. 정상적으로 AOP가 적용될 메서드를 선택하는 부분이기 때문에 올바른 패키지명과 클래스명을 지정해야 합니다.
AOP 설정이 올바로 되어 있는지 확인해야 합니다. 스프링 설정 파일 또는 자바 설정 클래스에서 AOP를 설정해주는지 확인해주세요. 일반적으로 aop:aspectj-autoproxy/ 태그를 스프링 설정 파일에 추가하여 AOP를 적용합니다.
위의 항목들을 확인하고 문제가 해결되지 않는다면, 더 상세한 정보를 제공해주시면 더 도움을 드릴 수 있을 것 같아요.
0
@Around("execution(* hello.helloSpring..*(..))")
여기서 Spring의 s가 대문자네요! 소문자로 하셔야 할 것 같아요
@Around("execution(* hello.hellospring..*(..))")
으로 바꾸신 후 실행해보세요