티스토리 뷰
0. 이 포스트는 Spring : AOP with Java Config 의 연속이다.
1. Aspect 클래스 내의 Advice의 실행순서는 정의된 것이 없다. 그냥 랜덤이다.
2. Advice의 순서를 관리하고 싶은 경우에는 advice마다 별도의 Aspect 클래스를 만들어 순서를 정할 수 있다.
2-1 @Order annotation을 사용하여 순서를 정할 수 있다.
2-2 @Order(숫자) 형식으로 순서를 정할 수 있는데 숫자가 낮을 수록 우선순위가 높다.
2-2-1 숫자는 -1, -100같은 음수도 가능하다.
2-2-2 순차적으로 사용할 필요가 없다. 1, 3, 100 이런 식으로 마음 대로 설정할 수 있다.
2-3 같은 숫자가 할당 되는 경우는 그 Aspect 클래스들만 랜덤으로 실행된다.
3. Aspect 단위로 point cut 사용하기
3-1 pointcut 설정 클래스를 별도로 만든다.
package pe.pilseong.spring_aop_review.aspect;
import org.aspectj.lang.annotation.Aspect;
import org.aspectj.lang.annotation.Pointcut;
import org.springframework.stereotype.Component;
@Aspect
@Component
public class AopExpressions {
@Pointcut(value = "execution(* pe.pilseong.spring_aop_review.dao.*.*(..))")
public void forDAOPackage() {}
@Pointcut(value = "execution(* pe.pilseong.spring_aop_review.dao.*.get*(..))")
public void getter() {}
@Pointcut(value = "execution(* pe.pilseong.spring_aop_review.dao.*.set*(..))")
public void setter() {}
@Pointcut(value = "forDAOPackage() && !(getter() || setter())")
public void forDAOPackageNoGetterSetter() {}
}
3-2 이 pointcut을 사용하는 여러 클래스를 생성한다.
3-2-1 중요한 부분은 외부의 pontcut을 사용하는 방법이다.
3-2-1-1 @Before나 advice annotation의 value에 fully qualifed name을 사용하면 된다.
3-2-1-2 pe.pilseong.spring_aop_review.aspect.AopExpressions.forDAOPackageNoGetterSetter()
// Aspect 1
package pe.pilseong.spring_aop_review.aspect;
import org.aspectj.lang.annotation.Aspect;
import org.aspectj.lang.annotation.Before;
import org.springframework.core.annotation.Order;
import org.springframework.stereotype.Component;
@Aspect
@Component
@Order(value = 1)
public class CloudLogAspect {
@Before("pe.pilseong.spring_aop_review.aspect.AopExpressions.forDAOPackageNoGetterSetter()")
public void cloudLogAdvice() {
System.out.println("Executing in cloudLogAdvice @Before advice on forDAOPackage() && !(getter() || setter())");
}
}
// Aspect 2
package pe.pilseong.spring_aop_review.aspect;
import org.aspectj.lang.annotation.Aspect;
import org.aspectj.lang.annotation.Before;
import org.springframework.core.annotation.Order;
import org.springframework.stereotype.Component;
@Aspect
@Component
@Order(value = 2)
public class LoggingDemoAspect {
@Before("pe.pilseong.spring_aop_review.aspect.AopExpressions.forDAOPackageNoGetterSetter()")
public void loggingDemoAdvice() {
System.out.println("Executing in loggingDemoAdvice @Before advice on forDAOPackage() && !(getter() || setter())");
}
}
// Aspect 3
package pe.pilseong.spring_aop_review.aspect;
import org.aspectj.lang.annotation.Aspect;
import org.aspectj.lang.annotation.Before;
import org.springframework.core.annotation.Order;
import org.springframework.stereotype.Component;
@Aspect
@Component
@Order(value = 3)
public class ApiAnalyticsAspect {
@Before("pe.pilseong.spring_aop_review.aspect.AopExpressions.forDAOPackageNoGetterSetter()")
public void apiAnalyticsAdvice() {
System.out.println("Executing in apiAnalyticsAdvice @Before advice on forDAOPackage() && !(getter() || setter())");
}
}
3-2-2 실행결과는 다음과 같다.
3-2-2-1 결과가 @Order에서 설정한 대로 작은 숫자의 Aspect가 먼저 실행되었음을 알 수 있다.
public class App {
public static void main(String[] args) {
AnnotationConfigApplicationContext context =
new AnnotationConfigApplicationContext(JavaConfig.class);
AccountDAO accountDAO = context.getBean("accountDAO", AccountDAO.class);
accountDAO.getAccount();
Account account = new Account();
accountDAO.addAccount(account, true);
MembershipDAO membershipDAO = context.getBean("membershipDAO", MembershipDAO.class);
membershipDAO.membership();
context.close();
}
}
// 실행 결과
class pe.pilseong.spring_aop_review.dao.AccountDAO: getAccount() with No Parameter. Doing my DB work: getting an account
Executing in cloudLogAdvice @Before advice on forDAOPackage() && !(getter() || setter())
Executing in loggingDemoAdvice @Before advice on forDAOPackage() && !(getter() || setter())
Executing in apiAnalyticsAdvice @Before advice on forDAOPackage() && !(getter() || setter())
class pe.pilseong.spring_aop_review.dao.AccountDAO: addAccount() with Account, boolean Parameter. Doing my DB work: Adding an account
Executing in cloudLogAdvice @Before advice on forDAOPackage() && !(getter() || setter())
Executing in loggingDemoAdvice @Before advice on forDAOPackage() && !(getter() || setter())
Executing in apiAnalyticsAdvice @Before advice on forDAOPackage() && !(getter() || setter())
class pe.pilseong.spring_aop_review.dao.MembershipDAO: membership() with No parameter. Doing my DB work: membership method is doing something
'Spring > Spring AOP' 카테고리의 다른 글
Spring : AOP with Java Config - @AfterRetuning advice (0) | 2020.05.13 |
---|---|
Spring : AOP with Java Config - Method Parameter 접근 (0) | 2020.05.13 |
Spring : AOP with Java Config - Combining Pointcut Expression (0) | 2020.05.12 |
Spring : AOP with Java Config - @Pointcut annotation (0) | 2020.05.12 |
Spring : AOP with Java Config - Parameter Pattern Wildcards (0) | 2020.05.12 |
- Total
- Today
- Yesterday
- 도커 개발환경 참고
- AWS ARN 구조
- Immuability에 관한 설명
- 자바스크립트 멀티 비동기 함수 호출 참고
- WSDL 참고
- SOAP 컨슈머 참고
- MySql dump 사용법
- AWS Lambda with Addon
- NFC 드라이버 linux 설치
- electron IPC
- mifare classic 강의
- go module 관련 상세한 정보
- C 메모리 찍어보기
- C++ Addon 마이그레이션
- JAX WS Header 관련 stackoverflow
- SOAP Custom Header 설정 참고
- SOAP Custom Header
- SOAP BindingProvider
- dispatcher 사용하여 설정
- vagrant kvm으로 사용하기
- git fork, pull request to the …
- vagrant libvirt bridge network
- python, js의 async, await의 차이
- go JSON struct 생성
- Netflix Kinesis 활용 분석
- docker credential problem
- private subnet에서 outbound IP 확…
- 안드로이드 coroutine
- kotlin with, apply, also 등
- 안드로이드 초기로딩이 안되는 경우
- navigation 데이터 보내기
- 레이스 컨디션 navController
- raylib
- 외부파일
- 설정
- 자바
- Spring Security
- one-to-many
- XML
- Rest
- one-to-one
- form
- Angular
- Many-To-Many
- mapping
- jsp
- crud
- login
- spring boot
- MYSQL
- 하이버네이트
- hibernate
- 설정하기
- 로그인
- 상속
- Validation
- 매핑
- Spring
- WebMvc
- 스프링부트
- RestTemplate
- Security
- 스프링