Spring

Spring Security + JWT

joaa 2023. 11. 7. 17:40

Spring Security:

Spring 기반 어플리케이션의 보안보안(인증인증, 권한 부여 및 보호보호)을 담당하는 스프링 하위 프레임워크

 

보안 용어 정리:

인증(Authentication): 접근하려는 유저가 누구인지 확인하는 절차절차 ex) 로그인
인가(Authorization): 인증된 사용자에 대해서 권한을 확인하고 허락하는 것
접근주체(principal): 보호된 대상에 접근하는 유저유저, 아이디
비밀번호(credential): 대상에 접근하는 유저의 비밀번호

 

Spring Security는 기본적으로 인증 절차를 거친 후에 인가 절차를 진행

Spring Security에서는 이러한 인증과 인가를 위해 Principal을 아이디로, Credential을 비밀번호로 사용하는 Credential 기반의 인증 방식을 사용

 

SecurityContextPersistenceFilter: SecurityContext를 로딩하여 설정
처음인증 혹은 익명 사용자일 경우: SecurityContext 생성하여SecurityContextHolder안에 저장을 하고 다음 필터 생성
이력이 있을 경우: SecurityContext꺼내와서꺼내와서SecurityContextHolder에 저장

 

LogoutFilter
-로그아웃 요청 시에만 실행

 

UsernamePasswordAuthenticationFilter
-ID와 비밀번호를 사용하는 유저 인증을 처리

 

ConcurrentSessionFilter
-동시 세션과 관련된 필터
-하나의 계정으로 인증 받은 사용자가 두 명 이상일 때 실행
-session.expireNow()

 

RememberMeAuthenticationFilter
-세션이 사라지거나 만료되어도 쿠키 또는또는DB를 사용하여 저장된 토큰 기반으로 인증을 처리
-remember-me기능 활성했는데 인증 받은 세션이 만료되면 실행
-remember-me cookie

 

AnonymousAuthenticationFilter
-사용자 정보가 인증되지 않았다면 익명 사용자 토큰을 반환
-필터가 호출되는 시점까지 인증 시도를 하지 않고 권한도 없이 어떤 자원에 바로 접속을 시도할 경우 실행


SessionManagementFilter
-로그인 후 세션과 관련된 작업을 처리처리(SessionInfo등록등록, SessionFixation, ConcurrentSession)

 

ExceptionTranslationFilter
-인증인증, 인가 예외가 발생했을 경우 실행


FilterSecurityInterceptor
-권한 부여와 관련한 결정을결정을AccessDecisionManager에 위임해 권한 부여 결정 및 접근 제어를 처리
-인증 객체가 존재하는지 확인 후후, 접근하고자 하는 자원의 승인과 거부를 판단

 

 

 

 

인증 방식(Cookie, Session, Token)

 

Cookie의 동작 과정
1. 브라우저(클라이언트)가 서버에 요청을 보낸다.
2. 서버는 클라이언트의 요청에 대한 응답을 작성할 때, 클라이언트 측에 저장하고 싶은 정보를 응답 헤더의 Set-Cookie에 담는다.
3. 이후 해당 클라이언트는 요청을 보낼 때마다 저장된 쿠키를 요청 헤더의 쿠키에 담아 보낸다.

 

Cookie vs Session
정보가 저장되는 공간이 다름
Cookie : 클라이언트에 저장됨
Session : 서버에 저장됨

 

Session의 동작 과정
1. 유저가 웹사이트에서 로그인하면 세션이 서버 메모리에 저장된다. 세션을 식별하기 위한 세션 ID를 기준으로 정보를 저장한다.
2. 서버에서 브라우저 쿠키에 세션 ID를 저장한다.
3. Cookie에 정보가 담겨있기 때문에 브라우저는 해당 사이트에 대한 모든 요청의 쿠키에 세션 ID를 담아 전송한다.
4. 서버는 클라이언트가 보낸 세션 ID와 서버 메모리로 관리하고 있는 세션 ID를 비교하여 인증을 수행한다.

 

Token의 동작 과정
1. 클라이언트가 서버에 접속을 하면 서버에서 해당 클라이언트에게 인증되었다는 의미로 토큰을 부여한다.
2. 토큰을 발급받은 클라이언트는 서버에 다시 요청을 보낼 때 요청 헤더에 토큰을 담아서 전송한다.
3. 서버에서는 클라이언트로부터 받은 토큰과 서버에서 제공한 토큰의 일치 여부 확인을 통해 인증 과정을 처리한다.

 

JWT 인증 과정
1. 사용자가 ID, PW를 입력하여 서버에 로그인 인증을 요청한다.
2. 서버가 Header, Payload, Signature를 정의한다. Header, Payload, Signature를 각각 Base64로 암호화하여 JWT를 생성하고 이 정보를 쿠키에 담아 클라이언트에게 발급한다.
3. 클라이언트는 서버로부터 받은 JWT를 로컬에 저장하고 API를 서버에 요청할 때 Authorization header에 Access Token을 담아서 보낸다.

4. 서버는 클라이언트가 Header에 담아서 보낸 JWT가 해당 서버에서 발행한 토큰인지 일치 여부를 확인하여 일치한다면 인증을 통과시키고 일치하지 않는다면 통과시키지 않는다. 인증이 되면 Payload에 있는 유저의 정보를 찾아서 클라이언트에 반환한다.
5. 클라이언트가 서버에 요청을 했는데 AccessToken이 만료된 상태라면 클라이언트는 Refresh Token을 이용해서 서버로부터 새로운 Access Token을 발급 받는다.