728x90
AspectV1

- @Around 애노테이션의 값인 execution(* hello.aop.order..*(..)) 는 포인트 컷이 된다.
- @Around 애노테이션의 메서드인 doLog 는 어드바이스( Advice )가 된다.
- execution(* hello.aop.order..*(..)) 는 hello.aop.order 패키지와 그 하위 패키지(.. )를 지정하는 AspectJ 포인트 컷 표현식이다. 앞으로는 간단히 포인트 컷 표현식이라 하겠다. 참고로 표인트컷 표현식은 뒤에서 자세히 설명하겠다.
- 이제 OrderService , OrderRepository 의 모든 메서드는 AOP 적용의 대상이 된다. 참고로 스프링은 프록시 방식의 AOP를 사용하므로 프록시를 통하는 메서드만 적용 대상이 된다.
참고
- 스프링 AOP는 AspectJ의 문법을 차용하고, 프록시 방식의 AOP를 제공한다. AspectJ를 직접 사용하는 것이 아니다.
- 스프링 AOP를 사용할 때는 @Aspect 애노테이션을 주로 사용하는데, 이 애노테이션도 AspectJ가 제공하는 애노테이션이다.
참고
- @Aspect 를 포함한 org.aspectj 패키지 관련 기능은 aspectjweaver.jar 라이브러리가 제공하는 기능이다. 앞서 build.gradle 에 spring-boot-starter-aop를 포함했는데, 이렇게 하면 스프링의 AOP 관련 기능과 함께 aspectjweaver.jar 도 함께 사용할 수 있게 의존 관계에 포함된다.
- 그런데 스프링에서는 AspectJ가 제공하는 애노테이션이나 관련 인터페이스만 사용하는 것이고, 실제 AspectJ가 제공하는 컴파일, 로드타임 위버 등을 사용하는 것은 아니다. 스프링은 지금까지 우리가 학습한 것처럼 프록시 방식의 AOP를 사용한다
Test
@Slf4j
@SpringBootTest
@Import(AspectV1.class)
public class AopTest {
@Autowired
OrderService orderService;
@Autowired
OrderRepository orderRepository;
@Test
public void aopInfo(){
log.info("isAopProxy, orderService={}", AopUtils.isAopProxy(orderService));
log.info("isAopProxy, orderRepository={}", AopUtils.isAopProxy(orderRepository));
}
@Test
public void success(){
orderService.orderItem("itemA");
}
@Test
public void exception(){
Assertions.assertThatThrownBy(() -> orderService.orderItem("ex"))
.isInstanceOf(IllegalStateException.class);
}
}
- @Aspect 는 애스펙트라는 표식이지 컴포넌트 스캔이 되는 것은 아니다. 따라서 AspectV1을 AOP로 사용하려면 스프링 빈으로 등록해야 한다.
- @Bean을 사용해서 직접 등록
- @Component 컴포넌트 스캔을 사용해서 자동 등록
- @Import 주로 설정 파일을 추가할 때 사용( @Configuration )
- AopUtils.isAopProxy(...) 도 프록시가 적용되었으므로 true를 반환한다.

728x90
'스프링 핵심 원리(고급편)' 카테고리의 다른 글
| Ch10. 스프링 AOP(구현) - 스프링 AOP 구현(어드바이스 추가) (0) | 2022.04.19 |
|---|---|
| Ch10. 스프링 AOP(구현) - 스프링 AOP 구현(포인트컷 분리) (0) | 2022.04.19 |
| Ch10. 스프링 AOP(구현) - 프로젝트 생성 (0) | 2022.04.18 |
| Ch09. 스프링 AOP 개념 - AOP 용어 정리 (0) | 2022.04.16 |
| Ch09. 스프링 AOP 개념 - AOP 적용 방식 (0) | 2022.04.16 |