H'academy
  • H'academy
  • Web
    • Back-end
      • Spring Framework
        • Spring 개발환경 구축
          • Project 생성
          • Maven 설정
          • Maven 저장소 위치 설정
          • Apache Tomcat 연동
          • Lombok 설정
        • Spring MVC Project
          • pom.xml
          • web.xml
          • root-context.xml
          • servlet-context.xml
          • DispatcherServlet
        • Controller
          • File Upload / Download
          • RestController(작성중)
        • Spring Test
          • Assert 단정문
          • Spring 환경 연동 테스트
          • MockMvc Test
        • Spring AOP
          • AOP 용어
          • Pointcut Expression
          • Filter
          • Interceptor
          • Filter vs Interceptor
          • Controller Advice(작성중)
        • Spring JDBC
          • DBCP
          • myBatis
            • ResultMap 활용
        • ETC
          • Logging
            • Tomcat Logging 설정
          • Property 관리
          • E-mail
            • Gmail 변경사항
          • Scheduler
          • Websocket
      • Spring Boot
        • STS 다운로드
        • 프로젝트 생성
        • 프로젝트 구조
        • Spring Devtools
        • Spring Controller
          • JSP 연동
            • * JSP 생성불가 문제
            • Spring Boot 3.x
          • Model
          • 요청 파라미터 처리
          • 경로 변수 처리
          • 요청 메소드
          • Redirect
          • Spring Actuator
        • Spring Boot JDBC
          • Database 정보
          • DAO Pattern
          • ORM Framework
            • myBatis
              • Mapper 생성
            • Spring Data JPA
        • Spring AOP
          • AspectJ
          • Filter
          • Interceptor
          • ControllerAdvice
        • REST API
        • Spring WebSocket
        • Send Mail
        • Logging
        • Spring Boot Test
        • Lombok
      • Java EE
        • 개발환경 구성
          • Server와 Client
          • Web Server와 WAS
        • Dynamic Web Project
      • Apache Tomcat
        • Apache Tomcat 구조
        • Tomcat User 생성
        • Tomcat Manager 설정
      • Maven
      • Jenkins
        • Installation
          • Github Webhook 설정
          • Maven 연동
        • Project setting
          • 소스 코드 관리 설정
          • 빌드 유발 설정
          • 빌드 작업 설정
      • OpenAPI(swagger)
        • swagger 2.x (legacy)
        • swagger 3.x (boot)
        • Swagger UI 꾸미기
        • SpringDoc
    • Front-end
      • HTML
        • Heading
        • <A>
        • <IMG>
        • <DIV>
        • <TABLE>
        • <FORM>
          • <INPUT>
          • <SELECT>
          • <TEXTAREA>
          • <FIELDSET>
        • List
      • CSS
        • CSS 적용 방식
          • 크기(size)
            • 픽셀(px)
          • 색상(color)
        • CSS 선택자
          • 스타일 우선순위
        • CSS 주요 속성
          • 크기 속성
            • border
            • margin
            • padding
            • box-sizing
          • 배경 속성
          • 글자 속성
            • font
            • text
          • 배치 속성
            • position
            • display
            • overflow
            • float
            • flexbox
        • CSS Reset
      • JS
        • syntax
          • let, const
          • 구조 분해 할당
          • spread operator
          • Object copy
          • this
          • module
        • jQuery
          • structure
          • function
          • ajax
            • ajax file upload
        • VueJS
          • CDN(Vue3)
            • 기본 구조
            • Vue Devtools
            • jQuery vs VueJS
            • Vue instance
              • data
                • IME issue
              • v-model
              • template
              • computed
              • watch
                • deep watch
                • vs Computed
              • methods
            • Vue directive
              • v-text
              • v-html
              • v-bind
                • v-bind style
                • v-bind class
              • v-on
                • once
                • prevent
              • v-show
              • v-if
              • v-for
          • Vue-cli 3
            • 프로젝트 구조
            • src
              • main.js
              • App.vue
              • HelloWorld.vue
            • Vue Router 4
              • History mode
              • 404 not found
              • Guard
                • beforeEach
            • Vuex
              • 이동 횟수 측정
            • axios
              • interceptor
          • Vue-electron
        • ReactJS
          • CDN(React18)
            • 템플릿 설명
            • JSX
            • render
            • Handling Events
              • onClick
              • onInput
            • Component
              • 클래스 컴포넌트
                • state
                • props
                • event
                  • Mouse
                  • Input
                • lifecycle
              • 함수형 컴포넌트
                • useState
                • useEffect
                • useReducer
                • useMemo
                • props
                • 조건부 렌더링
          • CRA
            • 자원 경로 설정
            • src 절대 경로 설정
            • react-router
            • Context API
            • Electron 설정
        • Webpack
          • NodeJS
          • Git
    • Ubuntu server
      • Jenkins
    • 테스트 도구
      • JMeter
        • Test Plan
        • Test Plan(with login)
        • Plugin 설치
    • WebRTC
  • Base Language
    • Java
      • Java 실행 과정
        • 개발 환경 구축
        • 샘플 코드 작성
        • 컴파일/실행
        • 환경 변수 설정
      • Java 초급
        • Hello world
        • 자료와 정보
        • 변수
          • 정수
            • 정수의 저장 원리
            • 정수형 변수 생성
          • 실수
            • 실수의 저장 원리
            • 실수형 변수 생성
          • 논리
            • 논리형 변수 생성
          • 문자
          • 문자열
            • 문자열 변수 생성
          • 사용자 정의 자료형
        • 연산자
          • 대입 연산
          • 부호 연산
          • 산술 연산
          • 복합 대입 연산
          • 증감 연산
          • 쉬프트 연산
          • 비트 연산
          • 비교 연산
          • 논리 연산
          • 삼항 연산
          • 변환 연산
        • 표준 입출력
          • 표준 출력
          • 표준 오류 출력
          • 표준 입력
            • Scanner 입력
        • 제어문
          • if 구문
            • 단일 조건
            • 두 가지의 조건
            • 여러 가지의 조건
          • switch~case 구문
          • while 구문
          • do~while 구문
          • for 구문
        • 랜덤(Random)
        • 배열
          • 1차원 배열
          • 2차원 배열
          • 다차원 배열
          • Sort
            • 선택 정렬
            • 버블 정렬
            • 삽입 정렬
      • Java 중급
        • 객체 지향 프로그래밍
        • 클래스
        • 인스턴스
        • 필드
        • 메소드
          • 설정(setter) 메소드
          • 반환(getter) 메소드
        • 생성자
        • 접근 제한
          • private
          • package
          • protected
          • public
        • 정적(static)
        • 불변(final)
        • 상수(constant)
        • 상속
          • this와 super의 이해
          • 멤버 변수 설정
          • 멤버 메소드 설정
          • 생성자 설정
        • 추상화
          • 추상 클래스
          • 인터페이스
        • 다형성
        • 중첩 클래스
          • 일반 중첩 클래스
          • static 중첩 클래스
          • 지역 중첩 클래스
          • 익명 중첩 클래스
      • Java API(작성중)
        • java.lang
        • java.util
        • java.text
        • java.time
        • java.io
        • java.net
        • java.sql
        • java.awt
        • javax.swing
      • Java 고급
        • 제네릭(Generic)
        • 열거형(Enum)
        • Annotation Type
          • Retention
          • Target
          • Nested Annotation
        • Java Reflection
          • Intro
          • Class
          • Field
          • Constructor
          • Method
          • Package
      • JDBC
        • 드라이버 로드
        • 연결 생성
          • JDBC Driver 유형
        • JdbcTemplate
      • Java 버전별 변경사항
        • Java 1.8
          • Lambda Expression
          • Stream API
          • java.time 패키지
        • Java 9
        • Java 12
          • switch~case
        • Java 13
          • Text Block
    • Arduino
      • 학습 준비
        • Reference
        • 아두이노 온라인 시뮬레이터
        • 전기의 이해
        • 그라운드(GND)의 이해
      • 개발 환경 구축
        • CH340 보드 설치
        • Editor 글꼴 설정
      • 아두이노 제어
        • 코드의 구성
        • 시리얼 출력
        • 디지털 출력
          • LED 출력
        • PWM 출력
        • 시리얼 입력
        • 디지털 입력
          • PIR 센서
        • 아날로그 입력
          • 온도 센서(LM35DZ)
          • 조도 센서
          • 가스 센서
        • 피에조 부저
        • 서보 모터 제어
          • 시리얼 서보 모터 제어
          • 스위치 서보 모터 제어
        • 온습도 센서(DHT-11)
        • LCD
      • 아두이노 통신
        • 블루투스(Bluetooth)
          • HC-06
            • 온도 센서 활용
          • HM-10
        • 와이파이(Wi-Fi)
          • ESP-01
            • WiFiEsp 라이브러리 추가
            • WiFiEsp 네트워크 스캔
        • 이더넷(Ethernet)
        • ArduinoJson 라이브리 사용
    • Regular Expression
  • Database
    • Oracle
      • 설치
        • SQL Plus
        • SQL Developer
        • DBeaver
        • Docker(Mac OS)
      • SQL
        • 관리자 명령
          • 사용자 관리
          • 권한 관리
          • Encoding 설정
          • 서비스 포트 설정
        • 사용자 명령
          • 테이블 관리
            • 테이블 항목 제약 조건
            • 외래키 제약조건
            • 데이터 유형
          • 시퀀스 관리
          • 데이터 관리
            • 데이터 추가
            • 데이터 조회
              • 오라클 내장 함수
              • 그룹 조회
              • Top N Query
            • 데이터 수정
            • 데이터 삭제
          • 뷰 관리
          • 인덱스 관리
          • 집합 연산
          • 테이블 조인
            • 등가 조인
            • 외부 조인
        • HR 계정
        • 기타 명령
          • 컬럼 간격 조정
      • 내보내기 및 불러오기
        • EXPDP, IMPDP
        • Docker로 실행중인 경우
      • 기타
        • 자동 세션 제거
        • Tablespace 관리
        • Unlock user
  • 면접대비
    • Q&A
      • Java
      • Database
      • Web
      • IT 일반상식
  • ETC
    • Eclipse IDE
      • 설치
      • 화면 설명
      • 환경 설정
      • 프로젝트 생성
      • 소스파일 작성 및 실행
    • Github
      • Github 계정 관리
      • Github 저장소 관리
        • Profile
        • Collaborators
        • Code
        • Issues
        • Pull requests
        • Action
          • Vue 3 Deploy Action
      • Personal Access Token
      • Git ignore 설정
        • Spring 개발용 샘플
      • Github Eclipse 연동
        • Branches
        • Project
        • Team project
          • Dynamic web project
          • Spring Boot Project
          • Branch 생성
          • Pull Request
          • Branch 보호
          • Branch 다시 생성
    • Figma
      • Team
      • Design
      • Component
    • 과정평가형
      • 실기 모의고사 1회
      • 실기 모의고사 2회
      • 실기 모의고사 3회
      • 실기 모의고사 4회
    • VScode
      • Live Server 실행 오류
      • Github 계정 변경
    • Naver ToastUI Editor
      • Editor 만들기
        • Editor options
          • File upload
      • Viewer 만들기
    • 문자 인코딩 방식
    • OBS
      • 녹화 잡음 제거 설정
    • Semantic Version
Powered by GitBook
On this page
  • Spring AOP
  • AOP란
  • 진행 절차
  • 프로젝트 생성
  • 의존성 추가
  • AOP 설정
  • Aspect 생성 및 설정
  • @Before
  • @After
  1. Web
  2. Back-end
  3. Spring Framework

Spring AOP

이 문서에서는 Spring Legacy Project를 기준으로 Spring AOP 를 적용하는 방법에 대해서 다룬다.

PreviousMockMvc TestNextAOP 용어

Last updated 2 years ago

Spring AOP

  • AOP의 개념을 이해하고 설명할 수 있다.

  • Spring Legacy Project에 AOP 설정을 수행할 수 있다.

  • AOP에 사용하는 aspectj 표현식을 작성할 수 있다.

AOP란

AOP는 Aspect Oriented Programming 의 줄임말이다. 직역하면 측면(관점) 지향 프로그래밍이 되는데 이를 조금 더 풀어서 설명한다면 내가 바라보는 관점에서 필요한 대상에게만 수행하는 프로그래밍이라고 볼 수 있다. Java와 Spring에서는 AsjectJ가 표준으로 사용되며 따라서 적용하려면 AsjectJ 관련 라이브러리들이 필요하다.

다음 그림을 보면서 추가적으로 AOP에 대해 이해해본다.

그림에 따르면 재료는 다음과 같이 필요하다.

  • 요리재료 : 밥, 떡, 쫄면사리, 오징어, 돼지고기, 김치, 계란, 간장, 참기름, 물엿, 버터, 고추장

  • 제육덮밥 : 밥, 돼지고기, 김치, 참기름, 고추장

  • 오징어덮밥 : 밥, 오징어, 참기름, 고추장

  • 버터밥 : 밥, 계란, 간장, 버터

  • 떡볶이 : 떡, 계란, 물엿, 고추장

  • 쫄볶이 : 떡, 쫄면사리, 계란, 물엿, 고추장

  • 쫄면 : 쫄면사리, 계란, 참기름, 고추장

요리 재료가 맞는지보다 중요한 것은 요리에 따라 필요한 재료가 다르다는 것이다. 즉, 하고자 하는 요리가 결정되면 재료를 바라보는 관점(Aspect)이 달라진다는 것이다. 관점이 무엇이냐에 따라서 필요한 재료가 달라지는 것처럼, 원하는 작업에 따라 다양한 대상들을 선별하는 것이 Aspect의 핵심이다.

이는 웹 애플리케이션 역시 마찬가지이다.

어느 시점으로 웹 애플리케이션을 바라보느냐에 따라서 필요한 컴포넌트가 달라지며, 이 관점에 알맞게 해당 컴포넌트를 간섭하여 특정 작업을 추가하는 것이 AOP의 최종 목표라고 볼 수 있다.

진행 절차

프로젝트 생성

Spring MVC Project를 생성한 뒤 다음과 같이 설정한다.

  • project이름 : springaop

  • base패키지 : com.hakademy.aop

의존성 추가

Spring-AOP를 위해서는 다음 의존성이 필요하다.

  • org.aspectj.aspectjrt(Spring MVC Project 기본 내장)

  • org.aspectj.aspectjweaver

  • org.springframework.spring-aop

버전은 작성 시점에 따라 달라질 수 있으며, 이 문서를 작성하는 시점에서는 다음과 같은 버전을 사용하였다.

  • aspectjrt, aspectjweaver : 1.9.5

  • spring-aop : 4.3.25.RELEASE

AOP 설정

Spring MVC Project에서는 모든 component-scan이 DispatcherServlet의 설정파일인 servlet-context.xml에 설정되어 있다. 원하면 바꿀 수도 있지만, 설정파일을 최소한으로 변경하여 사용하기 위해 servlet-context.xml에 AOP 설정을 한다.

Auto Proxy에 대해서는 하위 문서에서 설명한다.

Aspect 생성 및 설정

본격적으로 간섭을 시도하려면 먼저 다음 내용들을 정해야 한다.

  1. 간섭하여 하고자 하는 내용을 작성

  2. 간섭하고자 하는 시점을 지정

  3. 간섭하고자 하는 대상을 수식으로 지정

수행할 내용은 다음과 같은 형태의 클래스로 정의한다.

@Aspect
@Component
public class TestAspect{

}

@Aspect 애노테이션을 이용하여 이 클래스는 간섭을 위한 것임을 명시한다. @Component 애노테이션을 이용하여 클래스를 스프링 컨테이너에 등록한다(@Service 등으로 등록해도 무방)

클래스 안에 내용은 다음과 같이 작성한다.

@Aspect
@Component
public class TestAspect{

    private static final Logger log = LoggerFactory.getLogger(TestAspect.class);
    
    public void before(){
        log.info("before 실행");
    }
    
}

Logger를 생략하고 싶다면 @Slf4j로 대체한다.

@Aspect
@Component
@Slf4j
public class TestAspect{

    public void before(){
        log.info("before 실행");
    }
    
}

다음은 간섭 시점을 설정해야 하는데, 간섭 시점은 크게 5가지로 구분된다.

  • @Before : 간섭 대상 실행 전

  • @After : 간섭 대상 실행 후

  • @AfterReturning : 간섭 대상 실행 성공시

  • @AfterThrowing : 간섭 대상 실행 오류시

  • @Around : 간섭 대상의 실행 전체상황

사용법이 비교적 간단한 @Before와 @After를 사용하여 간섭 시점을 설정해본다.

@Before("target(com.hakademy.aop.HomeController)")
@After("target(com.hakademy.aop.HomeController)")

위의 두 애노테이션을 번갈아서 메소드에 작성해본 뒤 어떠한 효과가 발생하는지에 대해서 살펴보도록 한다. target은 대상 패키지나 클래스를 지정할 때 사용하는 명령이며, 자세한 종류는 하위 문서에서 다룬다.

@Before

@Aspect
@Component
@Slf4j
public class TestAspect{

    @Before("target(com.hakademy.aop.HomeController)")
    public void before(){
        log.info("before 실행");
    }
    
}

실행하면 다음과 같은 결과 화면이 나온다.

INFO : com.hakademy.aop.aspect.TestAspect - before 실행
INFO : com.hakademy.aop.HomeController - Welcome home! The client locale is ko_KR.

기본적으로 제공되는 HomeController를 간섭했기 때문에 HomeController의 모든 메소드가 실행될 때마다 @Before 시점에 우리가 추가한 간섭 객체 @Aspect의 메소드가 실행된다.

@After

@Aspect
@Component
@Slf4j
public class TestAspect{

    @After("target(com.hakademy.aop.HomeController)")
    public void after(){
        log.info("after 실행");
    }
    
}

실행하면 다음과 같은 결과 화면이 나온다.

INFO : com.hakademy.aop.HomeController - Welcome home! The client locale is ko_KR.
INFO : com.hakademy.aop.aspect.TestAspect - after 실행

HomeController의 모든 메소드가 실행될 때마다 @After 시점에 우리가 추가한 간섭 객체 @Aspect의 메소드가 실행된다.

이 외에도 @AfterReturning, @AfterThrowing을 테스트해보면 대략적인 시점을 알 수 있다. (단, @AfterThrowing은 대상 실행 중 예외 발생 시에만 확인이 가능하다)

요리 재료를 관점(Aspect)에 따라 분류
웹 애플리케이션의 관점에 따른 분류
Spring-AOP 네임스페이스 추가
AspectJ Auto Proxy 설정 추가