[Spring] Spring AOP

Junwon SEO·2022년 11월 19일
0

Spring 스터디

목록 보기
4/5

이번에는 스프링 프레임워크의 3대 개념인 DI, IoC, AOP 중 마지막인 AOP에 대해 알아보았다.

1. AOP ( Aspect Oriented Programing ) : 관점 지향 프로그래밍

어떤 로직을 기준으로 핵심적인 관점, 부가적인 관점으로 나눠서 보고 그 관점을 기준으로 각각 모듈화하는 것.

여기서 모듈화란 어떤 공통된 로직이나 기능을 하나의 단위로 묶는 것을 말한다. 예를 들어 핵심적인 관점은 결국 우리가 적용하고자 하는 핵심 비즈니스 로직이 된다. 또한 부가적인 관점은 핵심 로직을 실행하기 위해서 행해지는 데이터베이스 연결, 로깅, 트랜젝션, 파일 입출력 등을 예로 들 수 있다.

AOP에서 각 관점을 기준으로 로직을 모듈화한다는 것은 코드들을 부분적으로 나누어서 모듈화하겠다는 의미다. 이때, 소스 코드상에서 다른 부분에 계속 반복해서 쓰는 코드들을 발견할 수 있는 데 이러한 것들을 흩어진 관심사 (Crosscutting Concerns)라 부른다.

AOP는 OOP를 대체하는 새로운 개념이 아니라 OOP를 돕는 보조적 기술 중에 하나 이다.

위와 같이 흩어진 관심사를 Aspect로 모듈화하고 핵심적인 비즈니스 로직에서 분리하여 재사용 하겠다는 것이 AOP의 취지이다.

2. AOP의 주요 개념

  • Aspect : 위에서 설명한 흩어진 관심사를 모듈화 한 것. 주로 부가기능을 모듈화한다.
  • Target : Aspect를 적용하는 곳 (클래스, 메서드 .. )
  • Advice : 실질적으로 어떤 일을 해야할 지에 대한 것이며 실질적인 부가기능을 담은 구현체이다.
  • JointPoint : Advice가 적용될 위치, 끼어들 수 있는 지점. 메서드 진입 지점, 생성자 호출 시점, 필드에서 값을 꺼내올 때 등 다양한 시점에 적용이 가능하다.
    PointCut : JointPoint의 상세한 스펙을 정의한 것으로, 'A란 메서드의 진입 시점에 호출할 것'과 같이 더욱 구체적으로 Advice가 실행될 지점을 정할 수 있다.

[ execution 명시자 ]

  • execution(수식어패턴 리턴타입패턴 클래스이름패턴.메서드이름패턴(파라미터패턴))
  • 각 패턴은 *을 이용하여 모든값을 표현할 수 있다.

[ 패키지 ]
com.spring.aop -> com.spring.aop패키지를 타겟
com.spring.aop.. -> com.spring.aop로 시작하는 하위의 모든 패키지를 타겟

[ 리턴타입 ]
1.   *  -> 모든 리턴 타입 타겟
2. void -> 리턴 타입이 void인 메서드만 타겟
3. !void -> 리턴 타입이 void가 아닌 메서드만 타겟

[ 매개 변수 지정 ]
1. (..) -> 0개 이상의 모든 파라미터 타겟
2. () -> 1개의 파라미터만 타겟
3. (
,) -> 2개의 파라미터만 타겟
4. (String,
) -> 2개의 파라미터중 첫번째 파라미터가 String타입만 타겟

[ 샘플 예시 ]

  • execution(void set*(..)) -> 리턴 타입이 void이고 메서드 이름이 set으로 시작하고 파라미터가 0개 이상인 메서드 타겟
  • execution( abc..*()) -> 모든 리턴타입 매칭 , abc패키지에 속한 파라미터가 없는 모든 메서드 타겟
  • execution( abc...*(..)) -> 모든 리턴타입 매칭 , abc패키지 및 하위 패키지에 있는 파라미터가 0개 이상인 메서드 타겟
  • execution ( get(*)) -> 모든 리턴타입 매칭 , 이름이 get으로 시작하고 파라미터가 한 개인 메서드 타겟
  • execution( get(,)) -> 모든 리턴타입 매칭 , 이름이 get으로 시작하고 파라미터가 2개인 메서드 타겟
  • execution( read(int,..)) -> 메서드명이 read로시작, 첫번째 파라미터 타입 int, 한개 이상 파라미터를 갖는 메서드 타겟
  • execution(int com.spring.aop.Boss.work(..)) 리턴 타입 int, com.spring.aop 패키지 안의 Boss클래스의 work 메서드 타겟

0개의 댓글