inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

서블릿 필터 - 인증 체크

로그인인증필터 로직 질문입니다.

393

코더

작성한 질문수 20

0

try{
    log.info("인증 체크 필터 시작{}",requestURI);
    if(isLoginCheckPath(requestURI)){
        log.info("인증 체크 로직 실행 {}",requestURI);
        HttpSession session = httpServletRequest.getSession(false);
        if(session==null || session.getAttribute(SessionConst.LOGIN_MEMBER) ==null){
            log.info("미인증 사용자 요청 {}", requestURI);
            //로그인으로 redirect
            httpServletResponse.sendRedirect("/login?redirectURL=" + requestURI);
            return;
        }
    }
    log.info("aaa");
    chain.doFilter(request,response);
}
catch (Exception e){
    throw e;
}
finally {
    log.info("인증 체크 필터 종료 {}" , requestURI);
}

강의자료에는 다음과 같이 되있습니다.

return; 여기가 중요하다. 필터를 더는 진행하지 않는다. 이후 필터는 물론 서블릿, 컨트롤러가 더는

호출되지 않는다. 앞서 redirect 를 사용했기 때문에 redirect 가 응답으로 적용되고 요청이 끝난다.

 

이렇게 강의자료에 되있는데 제가 위 코드처럼 임의로 log.info("aaa")를 추가하고 돌린결과 미인증사용자 요청if문에 걸려서 return이 걸리면 return 때문에 다음필터호출x,서블릿,컨트롤러호출x 때문에 로그 aaa가 안나와야 되는거 아닌가요? 왜 return을 썼는데 log.info("asdasdsdasdads"); chain.doFilter(request,response); 이 두줄이 실행되는지 궁금합니다.

spring mvc

답변 2

0

OMG

안녕하세요. 코더님, 공식 서포터즈 OMG입니다. AI 답변에 더하여 답변 드립니다.

미인증 사용자 if문 바깥의 if( isLoginCheckPath() 가 실행되지 않아

log.info("인증 체크 필터 시작{}",requestURI);

log.info("aaa");

chain.doFilter(request,response);

위 3줄만 실행된 것 같습니다.

isLoginCheckPath()를 확인해주세요 :)

private boolean isLoginCheckPath(String requestURI) {
    return !PatternMatchUtils.simpleMatch(whitelist, requestURI);
}

 

 

감사합니다.

0

코더

감사합니다!

0

인프런 AI 인턴

안녕하세요, 인프런 AI 인턴이에요.

위 코드에서 if문에서 return 문을 만나면, 해당 필터 메소드는 더 이상 진행되지 않고 종료됩니다. 따라서, “log.info(“aaa”)” 문장은 실행되지 않습니다. return이 실행되고 나면, 해당 요청은 더 이상 다음 필터, 서블릿, 컨트롤러를 호출하지 않게 됩니다.

따라서, 위 코드에서 return 문을 만나면 redirect로 인해 요청이 끝나고 종료되기 때문에 “log.info(“aaa”)” 문장은 실행되지 않습니다.

추가적인 질문이 있으시면 언제든지 물어보세요. 감사합니다.

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

0

46

1

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

0

55

2

MessageSourceTest 코드

0

49

1

인터셉터 에러 설정

0

48

1

resolveArgument()메서드 질문

0

58

1

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

0

60

2

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

2

133

3

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

0

93

3

pdf 오타 문의

0

57

1

ItemUpdateForm 검증 관련 질문입니다.

0

50

1

22page 링크 주소 변경

0

59

2

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

0

53

1

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

0

80

2

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

0

87

2

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

0

66

1

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

0

143

3

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

0

65

1

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

0

105

2

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

0

81

1

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

0

119

2

ApiExceptionController 질문드립니다.

0

64

1

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

0

66

1

MemberRepository 필드의 fianl 선언 유무

0

85

2

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

0

59

1