스프링 MVC 2 - 쿠키와 보안 문제
반응형
쿠키와 보안 문제
쿠키를 사용해서 로그인 Id를 전달해서 로그인을 유지할 수 있었다. 그런데 여기에는 심각한 보안 문제가 있다.
보안 문제
- 쿠키 값은 임의로 변경할 수 있다.
- 클라이언트가 쿠키를 강제로 변경하면 다른 사용자가 된다.
- 실제 웹 브라우저 개발자모드 → Application → Cookie 변경으로 확인
- Cookie: memberId=1 → Cookie: memberId=2 (다른 사용자의 이름이 보임)
- 쿠키에 보관된 정보는 훔쳐갈 수 있다.
- 만약 쿠키에 개인정보나, 신용카드 정보가 있다면?
- 이 정보가 웹 브라우저에도 보관되고, 네트워크 요청마다 계속 클라이언트에서 서버로 전달된다.
- 쿠키의 정보가 나의 로컬 PC에서 털릴 수 있고, 네트워크 전송 구간에서 털릴 수도 있다.
- 해커가 쿠키를 한번 훔쳐가면 평생 사용할 수 있다.
- 해커가 쿠키를 훔쳐가서 그 쿠키로 악의적인 요청을 계속 시도할 수 있다.
이런 식으로 만약에 memberId=2라는 쿠키를 알고있으면 요청을 보낼때 Cookie헤더에 memberId=2로 요청을 보내면 해당아이디에 접근이 가능하다.
대안
- 쿠키에 중요한 값을 노출하지 않고, 사용자 별로 예측 불가능한 임의의 토큰(랜덤 값)을 노출하고, 서버에서 토큰과 사용자 id를 매핑해서 인식한다. 그리고 서버에서 토큰을 관리한다.
- 토큰은 해커가 임의의 값을 넣어도 찾을 수 없도록 예상 불가능해야 한다.
- 해커가 토큰을 털어가도 시간이 지나면 사용할 수 없도록 서버에서 해당 토큰의 만료시간을 짧게(예: 30분)유지한다.
또는 해킹이 의심되는 경우 서버에서 해당 토큰을 강제로 제거하면 된다.
반응형
'Spring' 카테고리의 다른 글
스프링 MVC 2 - 로그인 처리하기 - 세션 직접 만들기 (0) | 2022.09.17 |
---|---|
스프링 MVC 2 - 로그인 처리하기 - 세션 동작 방식 (0) | 2022.09.16 |
스프링 MVC 2 - 로그인 처리하기 - 쿠키 사용 (0) | 2022.09.11 |
스프링 MVC 2 - 로그인 기능 (0) | 2022.09.11 |
스프링 MVC 2 - 회원 가입 (0) | 2022.09.10 |
댓글
이 글 공유하기
다른 글
-
스프링 MVC 2 - 로그인 처리하기 - 세션 직접 만들기
스프링 MVC 2 - 로그인 처리하기 - 세션 직접 만들기
2022.09.17 -
스프링 MVC 2 - 로그인 처리하기 - 세션 동작 방식
스프링 MVC 2 - 로그인 처리하기 - 세션 동작 방식
2022.09.16 -
스프링 MVC 2 - 로그인 처리하기 - 쿠키 사용
스프링 MVC 2 - 로그인 처리하기 - 쿠키 사용
2022.09.11 -
스프링 MVC 2 - 로그인 기능
스프링 MVC 2 - 로그인 기능
2022.09.11