인프런 커뮤니티 질문&답변
로그인인증필터 로직 질문입니다.
작성
·
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”)” 문장은 실행되지 않습니다.
추가적인 질문이 있으시면 언제든지 물어보세요. 감사합니다.






감사합니다!