AOP가 적용되지않습니다.
2181
작성한 질문수 6
학습하는 분들께 도움이 되고, 더 좋은 답변을 드릴 수 있도록 질문전에 다음을 꼭 확인해주세요.
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..*(..))")으로 바꾸신 후 실행해보세요
..
0
83
2
Unused property.....
0
104
2
project JDK is misconfigured
0
138
2
외부 API의 ID 타입(String/UUID)과 내부 도메인의 ID 타입(Long)이 불일치할 때의 설계 정석
0
84
2
단위/통합 테스트 버전충돌 문제
0
91
2
❗️springboot 4.0.2 버전 aspectj dependency 설정❗️
0
232
1
왜 컨트롤러는 변한게 없는데 새로 만든 html 파일이 뜨나요?
0
105
2
윈도우 build test오류 질문
1
103
2
테스트 관련 공부에 대한 조언을 얻고 싶습니다
0
102
2
테스트 실행 시 에러 질문
0
295
1
name을 통한 비교와 객체를 통한 비교
0
77
1
빌드 후 libs 없음
1
132
1
윈도우 gradlew.bat 에러
0
170
1
@PostMapping("/members/new")가 동작하지 않습니다
0
91
1
java static class와 kotlin class
0
80
1
스프링 DB연결
0
128
1
소요 시간
0
89
2
ddl.sql에 빨간 밑줄
1
102
2
welcome page 에러
0
186
3
잘 모르겠습니다.
0
164
2
fail을 똑같이 쳤는데 오류가 발생해요
0
159
2
index.html Welcome page
0
127
1
프로젝트 gradle-groovy ?
0
382
1
테스트코드 메서드명 한글
0
205
2





