250x250
Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | 5 | 6 | 7 |
8 | 9 | 10 | 11 | 12 | 13 | 14 |
15 | 16 | 17 | 18 | 19 | 20 | 21 |
22 | 23 | 24 | 25 | 26 | 27 | 28 |
29 | 30 |
Tags
- dfs
- querydsl
- 스토어드 프로시저
- 백트래킹
- 일대다
- 유니크제약조건
- exclusive lock
- 낙관적락
- 힙
- CHECK OPTION
- fetch
- 연관관계
- 데코레이터
- 비관적락
- 스프링 폼
- 이진탐색
- 다대다
- 지연로딩
- 연결리스트
- 즉시로딩
- eager
- 동적sql
- shared lock
- SQL프로그래밍
- 다대일
- FetchType
- JPQL
- execute
- PS
- BOJ
Archives
- Today
- Total
흰 스타렉스에서 내가 내리지
Custom Annotation 어노테이션 만들기 (@LoginUser) 본문
728x90
/**
* 1.
* 이 어노테이션이 생성될 수 있는 위치를 지정한다.
* PARAMETER로 지정했으니 메소드의 파라미터로 선언된 객체에서만 사용할 수 있다.
* 이 외에도 클래스 선언문에 쓸 수 있는 TYPE 등이 있다.
*/
/**
* 2.
* @Retention 어노테이션은 라이프사이클,
* 즉, 어노테이션이 언제까지 살아 남아 있을지를 정하는 역할을 한다.
*/
@Target(ElementType.PARAMETER) // 1
@Retention(RetentionPolicy.RUNTIME) // 2
public @interface LoginUser {
}
@RequiredArgsConstructor
@Component
public class LoginUserArgumentResolver implements HandlerMethodArgumentResolver {
private final HttpSession httpSession;
/**
* 컨트롤러 메서드의 특정 파라미터를 지원하는지 판단한다.
* 여기서는 파라미터에 @LoginUser 어노테이션이 붙어 있고, 파라미터 클래스 타입이 SessionUser.class 인 경우 true를 반환한다.
*/
@Override
public boolean supportsParameter(MethodParameter parameter){
boolean isLoginUserAnnotation = parameter.getParameterAnnotation(LoginUser.class) != null;
boolean isUserClass = SessionUser.class.equals(parameter.getParameterType());
return isLoginUserAnnotation && isUserClass;
}
/**
* 파라미터에 전달할 객체를 생성한다.
* 여기서는 세션에서 객체를 가져온다.
*/
@Override
public Object resolveArgument(MethodParameter parameter, ModelAndViewContainer mavContainer,
NativeWebRequest webRequest, WebDataBinderFactory binderFactory) throws Exception{
return httpSession.getAttribute("user");
}
}
/**
* @LoginUser 를 사용하기 위한 환경이 구성되었다.
* 이제 LoginUserArgumentResolver가 스프링에서 인식될 수 있도록 WebMvcConfigurer에 추가한다.
*/
@RequiredArgsConstructor
@Configuration
public class WebConfig implements WebMvcConfigurer {
private final LoginUserArgumentResolver loginUserArgumentResolver;
@Override
public void addArgumentResolvers(List<HandlerMethodArgumentResolver> argumentResolvers){
argumentResolvers.add(loginUserArgumentResolver);
}
}
* HandlerMethodArgumentResolver는 항상 WebMvcConfigurer의 addArgumentResolvers()를 통해 추가해야 한다.
* 다른 HandlerMethodArgumentResolver가 필요하다면 같은 방식으로 추가하면 된다.
'Spring' 카테고리의 다른 글
Spring Boot profile 환경별 설정하기 (0) | 2023.01.26 |
---|---|
로그 남기기 1 (0) | 2023.01.22 |
@Transactional(readOnly = true) (0) | 2023.01.18 |
스프링에서 Bean을 주입받는 방식 (0) | 2023.01.17 |
Filter, Interceptor, AOP의 차이 (0) | 2023.01.16 |