inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

스프링 MVC 2편 - 백엔드 웹 개발 활용 기술

@ControllerAdvice

쿼리 실행시 예외에 관하여 질문이 있습니다.

263

gleys

작성한 질문수 2

0

학습하는 분들께 도움이 되고, 더 좋은 답변을 드릴 수 있도록 질문전에 다음을 꼭 확인해주세요.

1. 강의 내용과 관련된 질문을 남겨주세요.
2. 인프런의 질문 게시판과 자주 하는 질문(링크)을 먼저 확인해주세요.
(자주 하는 질문 링크: https://bit.ly/3fX6ygx)
3. 질문 잘하기 메뉴얼(링크)을 먼저 읽어주세요.
(질문 잘하기 메뉴얼 링크: https://bit.ly/2UfeqCG)

질문 시에는 위 내용은 삭제하고 다음 내용을 남겨주세요.
=========================================
[질문 템플릿]
1. 강의 내용과 관련된 질문인가요? (예/아니오)
2. 인프런의 질문 게시판과 자주 하는 질문에 없는 내용인가요? (예/아니오)
3. 질문 잘하기 메뉴얼을 읽어보셨나요? (예/아니오)

[질문 내용]
여기에 질문 내용을 남겨주세요.

Order result = Optional.ofNullable(query
        .selectFrom(order)
        .innerJoin(order.orderProduct, orderProduct).fetchJoin()
        .leftJoin(orderProduct.review, review).fetchJoin()
        .innerJoin(orderProduct.product, product).fetchJoin()
        .where(order.id.eq(orderId))
        .fetchOne()).orElseThrow(() -> new IllegalArgumentException("존재하지 않는 주문번호 입니다."));

db에 접근하여 결과가 없을 경우 IllegalArgumentException을 던지도록 하였고

@ControllerAdvice
public class GeneralExceptionHandler {
...
@ExceptionHandler({
    IllegalArgumentException.class,
    IllegalStateException.class,
    ConstraintViolationException.class,
    NoSuchElementException.class,
    MethodArgumentNotValidException.class //valid 검증 exception
})
public ResponseEntity<?> handleIllegalArgumentException(Exception e) {
    log.info("Bad request exception occurred: {}", e.getMessage(), e);
}

ExceptionHandler에서 IllegalArgument를 잡도록 한뒤 일부러 존재하지 않는 값으로 조회를 하여 오류를 발생 시켰습니다.

정상적인 경우라면 당연히 ExceptionHandler에서 이를 잡아서 처리를 해야하지만 이상하게 예외가 handler 에서 잡히지가 않아 임의로 컨트롤러에서 이와 같이 잡은 후에 로그를 확인하였습니다.

@GetMapping("{id}")
public Result<OrderResponse> findById(@PathVariable Long id) {

    try{
        return success(orderService.findById(id));
    }
    catch (Exception e) {
        log.info("exception {}", e.getClass());
    }
    return null;
}

2022-10-18 00:29:26.063 INFO 41493 --- [nio-8080-exec-2] c.g.o.orders.Controller.OrderController : exception class org.springframework.dao.InvalidDataAccessApiUsageException

로그 출력 결과 위와 같은 InvalidDataAccessApiUsageException 이 출력이 되었는데 dispatcher servlet에서 자동으로 exception을 바꿔주나요?

 

Order result = Optional.ofNullable(query
        .selectFrom(order)
        .innerJoin(order.orderProduct, orderProduct).fetchJoin()
        .leftJoin(orderProduct.review, review).fetchJoin()
        .innerJoin(orderProduct.product, product).fetchJoin()
        .where(order.id.eq(orderId))
        .fetchOne()).orElseThrow(() -> new NotFoundException("존재하지 않는 주문번호 입니다."));

쿼리 조회하는 부분이 이해가 가질 않아 제가 임의로 만든 NotFoundException 으로 바꿔서 예외를 던질경우 정상적으로 ExceptionHandler에서 처리가 진행됩니다.커스텀 예외를 제외하고 Illegal로 시작하는 일부 예외들에 관하여 InvalidDataAccessApiUsageException 으로 바뀌게 되는데 이 부분이 이해가 잘 가지 않습니다.

spring MVC

답변 1

0

김영한

안녕하세요. gleys님

전체 프로젝트를 압축해서 구글 드라이브로 공유해서 링크를 남겨주세요.

구글 드라이브 업로드 방법은 다음을 참고해주세요.

https://bit.ly/3fX6ygx

주의: 업로드시 링크에 있는 권한 문제 꼭 확인해주세요

추가로 다음 내용도 코멘트 부탁드립니다.

1. 실행 방법을 알려주세요.

2. 어떻게 문제를 확인할 수 있는지 자세한 설명을 남겨주세요.

감사합니다.

 

이미지 업로드와 db 트랜잭션 묶는법

0

71

1

Could not resolve org.springframework.boot:spring-boot-starter-validation:2.4.4

0

93

2

MessageSourceTest 코드

0

68

1

인터셉터 에러 설정

0

70

1

resolveArgument()메서드 질문

0

72

1

43강 검증1 에서 실패 로직 관련 질문있습니다.

0

82

2

타임리프 3.X 버전 rendering, serializer 에러 해결 방법

2

162

3

스프링 빈에 등록이 안되는거 같은데 어떻게 하면 좋을까요?ㅠㅠ

0

124

3

pdf 오타 문의

0

66

1

ItemUpdateForm 검증 관련 질문입니다.

0

62

1

22page 링크 주소 변경

0

71

2

특정 데이터와 파일을 함께 저장 시, 테이블 구조 질문

0

61

1

섹션3번 수업에 대한 질문입니다.

0

99

2

@Autowired 보다 더 좋은 방법이 어떤 걸까요?

0

99

2

타입컨버터 가 람다랑 비슷해 보이는데 저의 생각이 맞는지?.

0

83

1

자바스크립트 인라인에서 객체 직렬화 시 오류가 납니다

0

159

3

스프링부트 - 오류페이지2 에서 500.html 에서 쓰인 객체 질문

0

82

1

톰캣 에러 페이지가 안보입니다.

0

121

2

apiEceptionController에서 센드 에러 호출하면 안되는지?

0

92

1

세션 타임아웃시 쿠키 삭제 방법이 없나요?

0

138

2

ApiExceptionController 질문드립니다.

0

72

1

셀렉박스 챕터에서 option value에 ==배송 방식 선택== 이것을 넣은 이유가 궁금함, 이렇게 구상해도 되는지?

0

69

1

MemberRepository 필드의 fianl 선언 유무

0

93

2

혹시 index.html 에서는 fragment 사용이 안되는건가요

0

64

1