로그인인증필터 로직 질문입니다.
393
작성한 질문수 20
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”)” 문장은 실행되지 않습니다.
추가적인 질문이 있으시면 언제든지 물어보세요. 감사합니다.
이미지 업로드와 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





