티스토리 뷰
Spring/Spring AOP
Spring : AOP with Java Config - @AfterRetuning advice
Korean Eagle 2020. 5. 13. 16:47728x90
0. 이 포스트는 Spring : AOP with Java Config 시리즈의 연속이다.
1. @AfterReturning은 타겟 메소드가 성공적으로 실행된 후 실행하게 된다. 예외가 발생하면 실행되지 않는다.
2. 실제 사용하는 상황들(@Before advice와 거의 동일하고 쌍으로 사용되는 경우가 많다.)
2-1 로깅, 보안처리, 트렌젝션 처리에 사용된다.
2-2 감사를 위한 logging에 사용될 수 있다. 사용자, 사용 메소드, 사용시점, 사용한 지점 등을 남길 수 있다.
2-3 호출자에게 값을 반환하기 전에 데이터 처리가 필요한 경우에 사용한다.
2-3-1 데이터의 포멧을 설정하거나 데이터를 추가 가공할 경우에 사용된다.
2-3-2 가공하더라도 반환 객체는 동일한 타입이어야 한다.
3. 예제 코드
// Aspect 클래스와 advice 정의
package pe.pilseong.spring_aop_review.aspect;
@Aspect
@Component
public class LoggingAspect {
@Before(value = "pe.pilseong.spring_aop_review.aspect.AopExpressions.forDAOPackageNoGetterSetter()")
public void beforeAdvice(JoinPoint joinPoint) {
System.out.println("\nExecuting in beforeAdvice @Before advice on forDAOPackage() && !(getter() || setter())");
}
@AfterReturning(value = "pe.pilseong.spring_aop_review.aspect.AopExpressions.forDAOPackageNoGetterSetter()")
public void afterAdvice() {
System.out.println("Executing in afterAdvice @Before advice on forDAOPackage() && !(getter() || setter())\n");
}
}
// 포인트 컷 설정 클래스
package pe.pilseong.spring_aop_review.aspect;
@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() {}
}
// 더미 DAO 1
package pe.pilseong.spring_aop_review.dao;
@Component
public class AccountDAO {
public void addAccount(Account account, boolean flag) {
System.out.println(getClass() + ": addAccount() with Account, boolean Parameter. Doing my DB work: Adding an account");
}
public Account getAccount() {
System.out.println(getClass() + ": getAccount() with No Parameter. Doing my DB work: getting an account");
return null;
}
}
// 더미 DAO 2
package pe.pilseong.spring_aop_review.dao;
@Component
public class MembershipDAO {
public void membership() {
System.out.println(getClass() + ": membership() with No parameter. Doing my DB work: membership method is doing something");
}
}
// 실행 클래스
package pe.pilseong.spring_aop_review;
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();
account.setName("Pilseong");
account.setLevel("Admin");
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 beforeAdvice @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 afterAdvice @Before advice on forDAOPackage() && !(getter() || setter())
Executing in beforeAdvice @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
Executing in afterAdvice @Before advice on forDAOPackage() && !(getter() || setter())
728x90
'Spring > Spring AOP' 카테고리의 다른 글
Spring : AOP with Java Config - @AfterThrowing (0) | 2020.05.13 |
---|---|
Spring : AOP with Java Config - @AfterReturning return data 수정 (0) | 2020.05.13 |
Spring : AOP with Java Config - Method Parameter 접근 (0) | 2020.05.13 |
Spring : AOP with Java Config - Aspect 실행 순서 설정 (0) | 2020.05.13 |
Spring : AOP with Java Config - Combining Pointcut Expression (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
TAG
- 로그인
- hibernate
- 자바
- Angular
- 스프링부트
- one-to-one
- one-to-many
- XML
- login
- 설정하기
- form
- Security
- mapping
- 스프링
- 상속
- MYSQL
- Spring Security
- Spring
- WebMvc
- spring boot
- Many-To-Many
- crud
- RestTemplate
- Validation
- Rest
- 하이버네이트
- 매핑
- 설정
- 외부파일
- jsp
250x250