강의

멘토링

커뮤니티

인프런 커뮤니티 질문&답변

ililil님의 프로필 이미지
ililil

작성한 질문수

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

스프링 인터셉터 - 인증 체크

인터셉터 무한루프

작성

·

106

0

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

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

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

[질문 내용]

안녕하세요 해당 강의처럼 인터셉터 두개를 사용하여 요청을 했더니 인터셉터가 계속 호출되는 오류가 발생하였습니다.

image.png


오류의 원인은 LoginCheckInterceptor의 exclude pattern에 /login 경로를 추가하지 않아 발생한 것이었습니다.

 

교안과 비교하며 주먹구구식으로 해결하였지만 능동적으로 해결하기 위해서는 어떤 과정을 거쳐야 하나요? 처음에는 두 인터셉터에 브레이크포인트를 찍어 디버깅 하려 했지만 여러 복잡한 코드들을 마주하게 되더라구요.. 어떻게 이런 오류를 해결해야 하나요?

답변 1

0

안녕하세요, 인프런 AI 인턴입니다. ililil님.

인터셉터를 사용할 때 무한 루프가 발생하는 문제는 흔히 발생할 수 있는 문제입니다. 보통 경로 설정이나 인터셉터 로직의 작은 실수가 원인이 될 수 있는데요, 이번 경우에는 LoginCheckInterceptorexcludePathPatterns/login 경로를 추가하지 않아서 발생한 것으로 보입니다.

이런 문제를 능동적으로 해결하기 위한 몇 가지 과정과 팁을 간단히 설명드리겠습니다:

  1. 경로 설정 검토: 인터셉터 별로 어떤 경로에 대해 작동하고, 어떤 경로는 제외해야 하는지 명확히 설정하는 것이 중요합니다. 이번 문제처럼 로그인 경로는 인증을 필요로 하지 않으므로 꼭 제외 경로에 추가해야 합니다.

  2. 디버깅 활용: 인터셉터의 무한 루프 문제를 해결하기 위해서는 디버깅이 필수적입니다.

    • 로그 확인: 기본적으로 로그를 자세히 분석하여 어디에서 문제가 발생하는지 확인합니다. 이때 로그 수준은 DEBUG로 설정하여 더 많은 정보를 볼 수 있도록 합니다.
    • 브레이크포인트 설정: IDE의 디버깅 도구를 통해 브레이크포인트를 적절히 설정합니다. URI 매칭에서 실행 흐름이 어떻게 되는지를 단계별로 확인하세요.
  3. 단순 코드 검토: 무한 루프가 발생하는 지점을 명확히 파악했다면, 해당 코드 블록이 올바른 행동을 하도록 단순화하거나 조건문을 명확히 합니다.

  4. 문서 및 교안 참고: 인터셉터의 기본 동작 방식과 필요에 따라 커스터마이징할 수 있는 옵션들을 숙지하는 것이 중요합니다. 종종 교안이나 관련 문서에서 해답을 찾을 수 있습니다.

관련된 자료로 아래의 링크들을 참고하시면 도움이 될 것 같습니다:

저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다.
현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏
추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.

ililil님의 프로필 이미지
ililil

작성한 질문수

질문하기