코딩항해기
[Spring] Filter, Interceptor, AOP 본문
AOP를 배우며 Filter에 차이점이 알고 싶어져 찾아보니 interceptor가 있다는 것을 알게되어 함께 정리한다.
횡단 기능 분리
AOP, 필터, 인터셉터 모두 횡단 기능(공통 로직)을 분리해 관리하기 위해 사용한다. 분리하지 않고 사용하게 되면 중복된 코드가 많아지고 유지보수가 어려워지며 수정 때마다 반복되는 컴파일로 인해 개발 비용이 증가한다.
이러한 공통 기능은 메서드 호출 앞, 중간, 뒤에 추가해 AOP, 필터, 인터셉터로 처리할 수 있다.
- Filter(필터) - 핸들러 동작의 전 후 과정에 부가로직 처리, 웹 컨테이너에서 관리
- Interceptor(인터셉터) - 이하 비슷함, 스프링 컨테이너에서 관리
- AOP(관점 지향 프로그래밍) - 메서드 동작의 전 후 과정에 부가로직 처리
Interceptor와 Filter는 Servlet 단위에서 실행된다. 반면, AOP는 메소드 앞에 Proxy패턴의 형태로 실행된다.
요청이 들어오면, Filter -> Intercepter -> AOP -> Intercepter -> Filter 순으로 거치게 된다.
또한 Filter는 스프링의 기능이 아닌 JAVA servlet에서 제공하는 기능이다. 스프링에 들어온 요청이 DispatcherServlet에 의해 컨프롤러에 매핑 되기 전, 후에 동작한다. (filter는 filterchain을 통해 여러 필터를 거치게 할 수도 있다.)
그렇기 때문에 Fliter는 인코딩 디코딩 역할을 수행하는 경우가 많다.
Intercepter는 요청에 대한 작업을 DispatcherServlet과 Handler(Controller)사이에서 전/ 후로 인터셉터 할 수 있다. Filter와의 차이점은 Intercepter가 스프링 기술이기 때문에 스프링에서 관리하는 빈들을 사용할 수 있다. 다국어 처리할 때 많이 사용된다.
AOP는 주로 로깅, 트랜잭션, 에러처리에 사용되며, Filter와 Intercepter와 다르게 비즈니스 로직을 처리할 때 사용된다. 메소드 전 후로 자유롭게 설정할 수 있다. Intercepter, Filter는 주소로 대상을 구분해서 걸러내야하는 반면, AOP는 주소, 파라미터, 어노테이션 등 다양한 방법으로 대상을 지정할 수 있다.
참고자료
https://memodayoungee.tistory.com/114
https://velog.io/@miot2j/Spring-Filter-Interceptor-AOP-%EC%B0%A8%EC%9D%B4-%EB%B0%8F-AOP%EB%A5%BC-%EC%82%AC%EC%9A%A9%ED%95%98%EC%97%AC-Logging%EC%9D%84-%EA%B5%AC%ED%98%84%ED%95%9C-%EC%9D%B4%EC%9C%A0
https://velog.io/@coco_116/AOP-Interceptor-Filter-%EC%9D%98-%EC%B0%A8%EC%9D%B4%EC%A0%90-Request%EA%B0%80-%EB%93%A4%EC%96%B4%EC%98%AC%EB%95%8C-%EA%B1%B0%EC%B9%98%EB%8A%94-%EC%88%9C%EC%84%9C-%EA%B0%81-%EC%97%AD%ED%95%A0%EB%93%A4%EC%9D%98-%EC%9E%A5%EC%A0%90%EC%9D%84-%EC%84%A4%EB%AA%85%ED%95%B4%EC%A3%BC%EC%8B%A4-%EC%88%98-%EC%9E%88%EC%9D%84%EA%B9%8C%EC%9A%94
'Spring' 카테고리의 다른 글
[Spring] 관점 지향 프로그래밍 AOP (@어노테이션) (0) | 2024.10.16 |
---|---|
[Spring] AOP의 JoinPoint (0) | 2024.10.15 |
[Spring] 관점 지향 프로그래밍 AOP (xml) (0) | 2024.10.15 |
[Spring] 비동기 Controller 구현 (ResponseBody, RequestBody, RestController) (0) | 2024.10.14 |
[Spring] Logback을 통한 로그 관리 기초 (@Slf4j) (0) | 2024.10.12 |