Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
기본 요구사항
Spring Security 환경설정
com.sprint.mission.discodeit.config
SecurityConfig
SecurityFilterChain
Bean을 선언하세요.SecurityFilterChain
을 등록하고, 이때 등록되는 필터 목록을 디버깅해보세요. 필터 목록은 PR에 첨부하세요.trace
로 설정하세요.CSRF 보호 설정하기
CsrfTokenRepository
구현체를CookieCsrfTokenRepository
로 설정하세요.HttpSessionCsrfTokenRepository
입니다.CsrfTokenRequestHandler
컴포넌트를 대체하세요.XorCsrfTokenRequestAttributeHandler
입니다.GET /api/auth/csrf-token
203 Void
CsrfToken
파라미터를 메서드 인자로 선언하면,HandlerMethodArgumentResolver
를 통해 자동으로 주입됩니다.회원가입
POST /api/users
Body UserCreateRequest, MultipartFile
200 UserDto
PasswordEncoder
를 통해 해시로 저장하세요.PasswordEncoder
의 구현체는BCryptPasswordEncoder
를 활용하세요.인증 - 로그인
formLogin
을 기본값으로 활성화하고, 추가된 필터를 확인해보세요.Spring Security의 formLogin 인증 흐름은 그대로 유지하면서 필요한 부분만 대체합니다.
UserDetails
UserDetailsService
PasswordEncoder
: 이전에 정의한BCryptPasswordEncoder
로 대체됩니다.AuthenticationSuccessHandler
AuthenticationFailureHandler
로그인을 처리할 url을
/api/auth/login
로 설정하세요.UserDetailsService
컴포넌트를 대체하세요.InMemoryUserDetailsManager
입니다.DiscodeitUserDetailsService
를 정의하세요.UserDetails 컴포넌트를 대체하세요.
org.springframework.security.core.userdetails.User
입니다.DiscodeitUserDetails
를 정의하세요.DiscodeitUserDetailsService
에서DiscodeitUserDetails
를 생성 후 반환하세요.AuthenticationSuccessHandler
컴포넌트를 대체하세요.SavedRequestAwareAuthenticationSuccessHandler
입니다.LoginSuccessHandler
를 정의하고 대체하세요.AuthenticiationFailureHandler
컴포넌트를 대체하세요.SimpleUrlAuthenticationFailureHandler
입니다.LoginFailureHandler
를 정의하고 대체하세요.이제 로그인 처리는 SecurityFilterChain에서 모두 처리되기 때문에 기존에 구현했던 로그인 관련 코드는 제거하세요.
AuthApi.login
,AuthController.login
AuthService.login
LoginRequest
인증 - 세션을 활용한 현재 사용자 정보 조회
UserDto
)를 가져올 수 있도록 API를 정의하세요.GET /api/auth/me
Header(자동 포함) Cookie: JSESSIONID=…
200 UserDto
SecurityFilterChain
의 필터를 통해 인증에 성공하면Controller
에서@AuthenticationPrincipal
를 통해 인증 정보에 접근할 수 있습니다.인증 - 로그아웃
- Logout 처리 URL
-
LogoutSuccessHandler
/api/auth/logout
로 설정하세요.LogoutSuccessHandler
컴포넌트를 대체하세요.SimpleUrlLogoutSuccessHandler
입니다.HttpStatusReturningLogoutSuccessHandler
로 대체하세요.인가 - 권한 정의
ADMIN
CHANNEL_MANAGER
USER
PUT /api/auth/role
Body UserRoleUpdateRequest
200 UserDto
ADMIN
권한을 가진 어드민 계정이 초기화되도록 구현하세요.DiscodietUserDetails.getAuthorities
를 수정하세요.인가 - 권한 적용
CHANNEL_MANAGER
권한을 가져야합니다.ADMIN
권한을 가져야합니다.SecurityFilterChain
GlobalExceptionHandler
RoleHierarchy
를 활용해 권한의 계층 구조를 정의하세요.심화 요구사항
세션 관리 고도화
sessionConcurrency
설정을 활용하세요.DiscodeitUserDetails
의equals()
,hashcode()
메소드를 오버라이딩하세요.sessionRegistry
를 활용하세요.로그인 고도화 - RememberMe
remember-me
)가true
인 경우 세션이 무효화되어도 자동으로 다시 로그인되도록 하세요.remember-me
파라미터가true
로 설정되어 요청합니다.remeberMe
설정을 활용하세요.JESSIONID
쿠키를 삭제 후 새로고침했을 때 인증 상태가 유지 되는지 확인해보세요.권한 적용 고도화
SpEL
을 활용해 Method Security 기반 리소스 보호 정책을 강화해보세요.멘토에게