강의

멘토링

커뮤니티

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

코더님의 프로필 이미지
코더

작성한 질문수

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

서블릿 필터 - 인증 체크

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

작성

·

387

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); 이 두줄이 실행되는지 궁금합니다.

답변 2

0

안녕하세요. 코더님, 공식 서포터즈 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

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

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

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

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

코더님의 프로필 이미지
코더

작성한 질문수

질문하기