개발/Spring(boot)
-
Custom Annotation을 만들고 AOP로 활용하는 법개발/Spring(boot) 2025. 1. 19. 23:53
이전 글을 읽고 보면 이해가 더 쉬울 것 같습니다. Spring Security 인가(Authorization)를 공부하다 보면 아래와 같은 코드를 마주치게 된다.@Componentpublic class BankService { @PreAuthorize("hasRole('ADMIN')") public Account readAccount(Long id) { // ... is only invoked if the `Authentication` has the `ROLE_ADMIN` authority }}"ADMIN" 권한이 있는 유저만 해당 메서드 또는 api에 접근할 수 있도록 통제하는 것 이다. 근데 AOP를 공부하다 보니 나만의 @PreAuthorize를 만들 수 있을 것 같았고이번 글은 나만..
-
@Transactional을 final class에 붙이면 안되는 이유(AOP의 동작원리)개발/Spring(boot) 2025. 1. 12. 23:06
업무를 하던 도중 for문을 돌며 데이터를 DB에 넣어주는 코드를 발견했다.그리고 데이터를 저장하는 연산이라 for문을 호출하는 메서드에 @Transactional을 붙여야 할 것 같아 해당 내용을 검토를 받고 어노테이션을 붙여주고자 했다.하지만 그 코드에 @Transactional을 붙이자 스프링부트 앱이 실행이 안되는 현상이 발생했다. 결론적으로 원인은 final class에 @Transactional을 붙여서 생긴 문제였고,final class에 @Transactional을 붙이면 안되는 이유는 아래와 같았다.1. @Transactional은 Spring AOP를 기반으로 동작하고, 2. AOP는 CGLIB Proxy를 생성하는 것 기반으로 동작한다.3. 추가적으로 @Transactional을 붙..
-
스프링의 DB 관련 예외 추상화개발/Spring(boot) 2025. 1. 5. 22:15
이번엔 DB의 예외를 다루면서 기술에 종속된다는 한계점을 겪고 좀 더 나은 방법에 대해 고민해보던 도중예외 추상화라는 키워드를 찾아 해당 내용에 대해 작성해보려 한다. 먼저 어떤 과정에서 해당 내용을 찾게 되었는지 간략하게 작성해보자면 아래와 같다. 업무를 하던 도중 정상적인 요청에 대해서도 Unique key 제약조건이 순간적으로 깨질 수 있는 상황이 발생했다. 예를들어 유저의 이름이 Unique할 때 여러 명의 유저 이름을 동시에 변경하려고 하면 문제가 생겼었다. 그래서 아래와 같은 방식으로 해결하면서 일시적으로 해결했다.// 1. 더미 데이터로 이름 변경private void setDummy(List updateDummeyUsers) { for (User user : updateDummeyUs..
-
ApplicationEventPublisher와 EventListener개발/Spring(boot) 2024. 12. 1. 16:30
ApplicationEventPublisher와 EventListener에 대해 궁금해져서 해당 내용에 대해 조금 더 알아보고 작성해보고자 한다. 먼저 알아보기 전 예시 코드를 보고 추측해봤던 두 코드의 기능은 다음과 같다.1. ApplicationEventPublisher는 이벤트를 Publish하고 그 이후에 행동에는 책임을 지지 않는다.2. EventListener는 원하는 이벤트가 발생했을 때 해당 이벤트를 감지하고 이후 비즈니스 로직을 처리한다. 여기까지가 추측했던 동작 방식이고 이제부터는는 실제로 해당 기능을 찾아보며 조금 더 구체적이고 새롭게 알게된 내용을 작성해보고자 한다.ApplicationEventPublisher의 내부 구조는 다음과 같다.@FunctionalInterfacepubli..