PermitAllFilter VS web.ignoring() 에 관한 질문입니다.
안녕하세요 강사님.
좋은강의 감사드립니다.
예제를 구현하기 이전에
java/resource/static/** 자원들에 대한 permit 설정을
아래와 같이 미리 해두었습니다
@Override
public void configure(WebSecurity web) throws Exception {
web// `/resource/` 내부 static, templates 등의 정적자원들을 "보안필터링 없이 외부공개"
.ignoring().antMatchers(
"/js/**"
, "/css/**"
, "/images/**"
)
.requestMatchers(PathRequest.toStaticResources().atCommonLocations());
}
이렇게 설정을 마친 후,
PermitAllFilter 와 permitAllUrls 구현 하고나서 확인이 되는 부분은 이렇습니다.
- FilterSecurityInterceptor 에서
PermitAllFilter 에서 걸러내지 못한 정적자원에 대한
permitAll 검사를 시도합니다.
`js/**, images/**, css/**` 등등..
( permitAllUrls 에 경로를 추가 시키면 permit 처리가 잘 됩니다 )
질문입니다
Security 기본제공 기능보다
PermitAllFilter 를 구현함으로 얻는 장점과,
Security 기본 permitAll 기능인 web.ignoring() 의 한계점이 궁금합니다.
읽어주셔서 감사드립니다.
답변 3
4
네
PermitAllFilter 를 구현해서 사용하는 이유는 두가지입니다.
첫째는 스프링 시큐리티의 인증, 인가 처리가 필터기반으로 동작하기 때문에 인가를 거치지 않아도 되는 자원을 필터링하는 기능도 필터기반으로 처리함으로써 전반적으로 일관성과 통일성을 가져다 주는 이점이 있습니다.
두번째는 강의에서 설명드리고 있는 내용입니다.
즉 스프링 시큐리티에서 인가를 처리하는 과정은 조금 복잡하고 여러 단계를 거치게 됩니다.
그렇기 때문에 인가처리를 필요로 하지 않는 자원은 복잡한 인가 처리 과정을 거칠 필요가 없이 PermitAllFilter 에서 간단하게 처리할 수 있게 됩니다.
조금 더 단순해 지는 효과가 있습니다.
물론 대단한 장점이 있는 것은 아닙니다
그리고 정적자원에 대한 설정은 web.ignoring() 사용하는 것이 맞습니다.
이 기능은 스프링 시큐리티의 필터 처리를 모두 스킵하는 것으로서 PermitAllFilter 기능과 다릅니다.
PermitAllFilter 기능은 필터는 거치되 인가처리를 하지 않도록 하는것이 목적입니다.
구분해서 이해하시면 됩니다.
2
네 그런 의미도 포함됩니다
다만 인가처리로 넘어가 버리면 matches 로직 외의 것들에 대한 처리를 다 거치기 때문에 앞단에서 간단하게 matches 기능에만 집중할 수 있게 됩니다
마치 프록시 역할과 비슷하다고 보시면 되겠습니다
0
PermitAllFilter를 생성함으로써 인가를 거쳐야 하는 자원에 대한 요청들은 불필요한 부가 matches연산을 거치게 되는데 이는 PermitAllFilter가 없을 때의 인가가 불필요한 자원들이 불필요한 matches연산을 거치는 것과 결국 똑같은 것이 아닌지 궁금합니다.
인가 처리 이전 화이트리스트가 존재한다는 것의 의의가 큰 것일까요?
시큐리티 공부 버전 질문
0
175
1
[해결 방법] MethodSecurityConfig.customMethodSecurityMetadataSource() 호출하지 않는 이슈
0
186
1
AbstractSecurityInterceptor.class.beforeInvocation()를 2번 실행하는 경우
0
174
1
강의 코드가 왜이렇게 뒤죽박죽인가요...
0
249
1
메인 페이지로 접속해도 login url로 리다이렉트가 되지 않습니다..
0
236
1
파라미터값이 넘어가지 않습니다 ....
0
374
1
security filterChain 설정 질문이 있습니다.
0
331
1
소스 부분 질문 드립니다.
0
208
2
섹션4 7번 강의 문제가 있는거 같네요.
0
344
2
파일이 수시로 이름이 바껴있네요 ㄷㄷ
0
304
1
HttpSessionSecurityContextRepository를 사용안하는 문제
0
555
2
error , exception 이 잘 안됩니다.
0
281
2
thymeleaf tag 질문합니다.
0
196
2
버전업하면서 deprecated된 것들이 너무많아요
0
478
1
spring security 패치 관련
0
437
1
모바일을 사용할때 토큰말고 세션
0
846
2
DB 연동한 인가 부분에 대한 질문입니다!
0
264
1
Ajax방식도 똑같이 Session방식을 사용하는건가요?
0
307
1
Config 파일 생성 시 질문이 있습니다.
0
225
1
강사님 몇일동안 구글 검색만 100개 했는데도 이유를 모르겠습니다..
1
429
2
403 에러 뜹니다.
0
813
2
login_proc의 존재에 대한 간략한 설명입니다
0
276
1
top.html에 로그인 링크를 만들어서 로그인을 해봤습니다
0
282
2
안녕하세요. DB에 저장될 때 이해 안 가는 값이 있어서 질문드립니다!
0
189
1





