inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

스프링 시큐리티

7) Remember Me 인증 필터 : RememberMeAuthenticationFilter

rememberme token key에 관한 질문입니다.

해결된 질문

572

dohyun_lim

작성한 질문수 67

1

안녕하세요 선생님 질문이 있습니다.

TokenBasedRememberService#processAutoLoginCookie 과정에서

String expectedTokenSignature = makeTokenSignature(tokenExpiryTime, userDetails.getUsername(),
      userDetails.getPassword());
if (!equals(expectedTokenSignature, cookieTokens[2])) {
   throw new InvalidCookieException("Cookie token[2] contained signature '" + cookieTokens[2]
         + "' but expected '" + expectedTokenSignature + "'");

위와 같이 해당 RemeberService가 생성되었을시 주입받은 key를 가지고 md5 방식으로 tokenSignature를 만드는것을 확인하였습니다.
이것을 받아온 rembemer me token하고 비교하는 것을 확인하였습니다.

 

질문이 2개입니다.

1) 이 과정을 거쳐서 만든 RememberMeAuthenticationToken 은
왜 아직 ProviderManager.authenticate를 거치지도 않았는데 authenticated=true인것 인가요?

 

2) 위의 인증객체(RememberMeAuthenticationToken )를 인증할때 RememberMeAuthenticationProvider#authenticate에서 key값을 추가적으로 비교하는 이유가 다른 질문을 찾아보니
"그리고  RememberMeServices 인터페이스를 커스텀하게 자체 기능을 구현할 수 있기 때문에 이 때에도 위와 같은 인증단계의 규칙을 거치게 함으로서 상호간 key 가 일치하지는 여부를 체크하기 위함이기도 합니다."

하셨는데 key가 달라도 MD5digest해서 나온 값이 같을 수도 있어서 추가적으로 검증한다고 이해하면 되나요?

java spring-boot Spring Security

답변 1

1

정수원

1번 질문

  • 해당 시점에서의 RememberMeAuthenticationToken 은 최종적으로 인증을 받았다라는 의미보다는 Remember-me 토큰의 유효성이 통과되었다라는 의미가 맞습니다. 굳이 표현하자면 1차 인증 성공이라 할 수 있고 이후 해시된 key 값을 검증하는 최종 인증을 위한 처리가 이루어지게 된다고 보시면 됩니다. 여담이지만 스프링 시큐리티에서 인증을 검증하고 성공시키는 처리는 무슨 특별한 룰이 있다기 보다는 보안적으로 더 잘 설계된 구조안에서 처리하기 위한 단계를 거친다고 보면 될 것 같습니다.

2번 질문

  • 일반적으로 인증 시 key 를 통해 암복호화 하거나 검증하는 방식은 private 한 키값을 통해 생성된 해시값은 인증을 시도하는 사용자가 동일한 키가 아니면 똑같은 해시 값을 만들어 낼 수 없다는 것을 증명하는 과정이라 볼 수 있습니다. 그런 관점에서 시큐리티 초기화 때 키값을 통해 만들어진 Remeber-me 쿠기값을 사용해 인증을 받기 위해서는 인증 시도자가 똑 같은 키를 가지고 있어야만 인증이 성공한다라는 개념이라 볼 수 있습니다.
    그리고 MD5digest 는 해시값을 만들어 내는데 키가 다르면 똑같은 결과가 나올 수 없습니다.
    요약하자면 토큰이든 쿠키든 대칭 혹은 비대칭키로 만들어진 해시 암호문은 동일한 키 혹은 검증할 수 있는 공개키에 의해 증명할 수 있다는 개념으로 이해하시면 됩니다.

시큐리티 공부 버전 질문

0

176

1

[해결 방법] MethodSecurityConfig.customMethodSecurityMetadataSource() 호출하지 않는 이슈

0

187

1

AbstractSecurityInterceptor.class.beforeInvocation()를 2번 실행하는 경우

0

179

1

강의 코드가 왜이렇게 뒤죽박죽인가요...

0

253

1

메인 페이지로 접속해도 login url로 리다이렉트가 되지 않습니다..

0

238

1

파라미터값이 넘어가지 않습니다 ....

0

375

1

security filterChain 설정 질문이 있습니다.

0

332

1

소스 부분 질문 드립니다.

0

210

2

섹션4 7번 강의 문제가 있는거 같네요.

0

345

2

파일이 수시로 이름이 바껴있네요 ㄷㄷ

0

306

1

HttpSessionSecurityContextRepository를 사용안하는 문제

0

557

2

error , exception 이 잘 안됩니다.

0

284

2

thymeleaf tag 질문합니다.

0

198

2

버전업하면서 deprecated된 것들이 너무많아요

0

478

1

spring security 패치 관련

0

437

1

모바일을 사용할때 토큰말고 세션

0

850

2

DB 연동한 인가 부분에 대한 질문입니다!

0

265

1

Ajax방식도 똑같이 Session방식을 사용하는건가요?

0

308

1

Config 파일 생성 시 질문이 있습니다.

0

228

1

강사님 몇일동안 구글 검색만 100개 했는데도 이유를 모르겠습니다..

1

433

2

403 에러 뜹니다.

0

813

2

login_proc의 존재에 대한 간략한 설명입니다

0

277

1

top.html에 로그인 링크를 만들어서 로그인을 해봤습니다

0

288

2

안녕하세요. DB에 저장될 때 이해 안 가는 값이 있어서 질문드립니다!

0

191

1