Spring Security - udemy
[섹션3] 유저 정의와 관리 - InMemoryUserDetailManager를 사용한 유저 설정
샐님
2024. 8. 16. 08:45
728x90
반응형
섹션3 의 목표 : 애플리케이션 메모리 안에 유저를 저장하여 여러 유저를 생성하는 방법을 배우고 데이터베이스와 같은 저장장치에 유저의 정보를 저장하는 방법을 배운다.
package wonCom.EaszBankBackend.config;
import org.springframework.boot.autoconfigure.security.SecurityProperties;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.core.annotation.Order;
import org.springframework.security.config.Customizer;
import org.springframework.security.config.annotation.web.builders.HttpSecurity;
import org.springframework.security.core.userdetails.User;
import org.springframework.security.core.userdetails.UserDetails;
import org.springframework.security.provisioning.InMemoryUserDetailsManager;
import org.springframework.security.web.SecurityFilterChain;
import static org.springframework.security.config.Customizer.withDefaults;
@Configuration //이 클래스 안에 특정 설정을 정의 , 시작단계에서 이 클래스 안에 우리가 정의한 모든 bean 을 스캔함.
public class ProjectSecurityConfig {
,,,
@Bean
public InMemoryUserDetailsManager userDetailsService(){
/*Approach 1 where we use withDefaultPasswordEncoder() method while creating the user details*/
/* UserDetails admin = User.withDefaultPasswordEncoder()
.username("admin")
.password("12345")
.authorities("admin")
.build();
UserDetails user = User.withDefaultPasswordEncoder()
.username("user")
.password("12345")
.authorities("read")
.build();
return new InMemoryUserDetailsManager(admin, user);
*/
/*Approach 2 where we use NoOpPasswordEncoder Bean while creating the user details*/
UserDetails admin = User.withUsername("admin")
.password("12345")
.authorities("admin")
.build();
UserDetails user = User.withUsername("user")
.password("12345")
.authorities("read")
.build();
return new InMemoryUserDetailsManager(admin, user);
}
// NoOppasswordEncoder : 운영 환경에서 권장되지 않음.
@Bean
public PasswordEncoder passwordEncoder(){
return NoOpPasswordEncoder.getInstance();
}
}
728x90
반응형