๐ก ์คํ๋ง์์ ์ธ์ฆ๊ณผ ๊ถํ ๋ถ์ฌ๋ก ๋ฆฌ์์ค ์ฌ์ฉ์ ์ปจํธ๋กคํ ์ ์๋ Spring Security ํ๋ ์์ํฌ์ ๋ํด ์์๋ณด์!
Notion ์์ ๋ณด๊ธฐ
๐ ์์ฝ
- Spring Security ์ ํต์ฌ์ ์ธ์ฆ๊ณผ ์ธ๊ฐ
๐ Spring Security ์์ ์ธ์ฆ๊ณผ ์ธ๊ฐ
- ๋ค๋ฅธ ๊ฒ์๊ธ์์ ์ ๋ฆฌํ ์ธ์ฆ๊ณผ ์ธ๊ฐ์ ๋ํด ์์๋ฅผ ๋ค์ด ์งง๊ฒ ์ง๊ณ ๋์ด๊ฐ์.
- ์ํ์ ๊ธ๊ณ ๊ฐ ์๊ณ , ์ฌ์ฉ์๊ฐ ๊ธ๊ณ ๋ฅผ ์ด์ด๋ณธ๋ค๊ณ ๊ฐ์ ํ ๋์ ๊ณผ์ ์ ์๋์ ๊ฐ๋ค.
- ์ฌ์ฉ์๋ ์ํ์ ๊ฐ์ ์์ ์ด ์ด๋ค ์ฌ๋์ธ์ง ์ ๋ถ์ฆ์ผ๋ก ์์ ์ ์ฆ๋ช ํ๋ค.
- ์ํ์์ ์ฌ์ฉ์์ ์ ๋ถ์ ํ์ธํ๋ค.
- ์ํ์์ ์ฌ์ฉ์๊ฐ ๊ธ๊ณ ๋ฅผ ์ด์ด ๋ณผ ์ ์๋ ์ฌ๋์ธ์ง๋ฅผ ํ๋จํ๋ค.
- ๋ง์ผ ์ ์ ํ ๊ถ๋ฆฌ๋ ๊ถํ์ด ์๋ ๊ฒฝ์ฐ ์ฌ์ฉ์์ ๊ธ๊ณ ๋ฅผ ์ด์ด์ค๋ค.
๐๐ป ์ธ์ฆ(Authentication)
- ํด๋น ์ฌ์ฉ์๊ฐ ๋ณธ์ธ์ด ๋ง๋์ง ํ์ธํ๋ ์ ์ฐจ
- ์์ ๊ณผ์ ์์ 1๋ฒ์ ํด๋น
๐๐ปโ๏ธ ์ธ๊ฐ(Authorization)
- ์ธ์ฆ๋ ์ฌ์ฉ์๊ฐ ์์ฒญํ ์์์ ์ ๊ทผ์ด ๊ฐ๋ฅํ์ง๋ฅผ ๊ฒฐ์ ํ๋ ์ ์ฐจ
- ์์ ๊ณผ์ ์์ 3๋ฒ์ ํด๋น
- Spring Security ๋ ๊ธฐ๋ณธ์ ์ผ๋ก ์ธ์ฆ ์ ์ฐจ๋ฅผ ๊ฑฐ์น ํ → ์ธ๊ฐ ์ ์ฐจ๋ฅผ ์งํ ํ๊ฒ๋๋ฉฐ,
- ์ธ๊ฐ ๊ณผ์ ์์ ํด๋น ๋ฆฌ์์ค์ ๋ํ ์ ๊ทผ ๊ถํ์ด ์๋์ง๋ฅผ ํ์ธํ๊ฒ ๋๋ค.
- ์ด๋ฌํ ์ธ์ฆ๊ณผ ์ธ๊ฐ๋ฅผ Principal ์ ์์ด๋๋ก - Credential ์ ๋น๋ฐ๋ฒํธ๋ก ์ฌ์ฉํ๋ Credential ๊ธฐ๋ฐ์ ์ธ์ฆ ๋ฐฉ์ ์ ์ฌ์ฉํ๋ค.
- Principal(์ ๊ทผ ์ฃผ์ฒด) : ๋ณดํธ ๋ฐ๋ ๋ฆฌ์์ค์ ์ ๊ทผํ๋ ๋์
- Credential(๋น๋ฐ๋ฒํธ) : ๋ฆฌ์์ค์ ์ ๊ทผํ๋ ๋์์ ๋น๋ฐ๋ฒํธ
๐ Spring Security ์ฃผ์ ๋ชจ๋
SecurityContextHolder
- SecurityContextHolder ๋ ๋ณด์ ์ฃผ์ฒด์ ์ธ๋ถ ์ ๋ณด๋ฅผ ํฌํจํ์ฌ, ์์ฉ ํ๋ก๊ทธ๋จ์ ํ์ฌ ๋ณด์ ์ปจํ ์คํธ์ ๋ํ ์ธ๋ถ ์ ๋ณด๊ฐ ์ ์ฅ๋๋ค.
SecurityContext
- SecurityContext ๋ Authentication ์ ๋ณด๊ดํ๋ ์ญํ ์ ํ๋ฉฐ, SecurityContext ๋ฅผ ํตํด Authentication ๊ฐ์ฒด๋ฅผ ๊บผ๋ด์ฌ ์ ์๋ค.
Authentication
- Authentication ์ ํ์ฌ ์ ๊ทผํ๋ ์ฃผ์ฒด์ ์ ๋ณด์ ๊ถํ์ ๋ด๋ ์ธํฐํ์ด์ค์ด๋ค.
- SecurityContext ์ ์ ์ฅ๋๋ฉฐ, SecurityContextHolder ๋ฅผ ํตํด SecurityContext์ ์ ๊ทผํ๊ณ → SecurityContext๋ฅผ ํตํด Authentication ์ ์ ๊ทผํ ์ ์๋ค.
public interface Authentication extends Principal, Serializable {
//ํ์ฌ ์ฌ์ฉ์์ ๊ถํ ๋ชฉ๋ก์ ๊ฐ์ ธ์ด
Collection<? extends GrantedAuthority> getAuthorities();
//credentials(์ฃผ๋ก ๋น๋ฐ๋ฒํธ)๋ฅผ ๊ฐ์ ธ์ด
Object getCredentials();
Object getDetails();
//Principal ๊ฐ์ฒด๋ฅผ ๊ฐ์ ธ์ด
Object getPrincipal();
//์ธ์ฆ ์ฌ๋ถ๋ฅผ ๊ฐ์ ธ์ด
boolean isAuthenticated();
//์ธ์ฆ ์ฌ๋ถ๋ฅผ ์ค์ ํจ
void setAuthenticated(boolean isAuthenticated) throws IllegalArgumentException;
}
UsernamePasswordAuthenticationToken
- Authentication ์ ๊ตฌํํ AbstractAuthenticationToken ์ ํ์ ํด๋์ค์ด๋ค.
- username : Pricipal์ ์ญํ
- password : Credential์ ์ญํ ์ ํ๋ค.
- ์ฒซ ๋ฒ์งธ ์์ฑ์๋ - ์ธ์ฆ ์ ์ ๊ฐ์ฒด๋ฅผ ์์ฑํ๊ณ ,
- ๋ ๋ฒ์งธ ์์ฑ์๋ - ์ธ์ฆ์ด ์๋ฃ๋ ๊ฐ์ฒด๋ฅผ ์์ฑํด์ค๋ค.
public class UsernamePasswordAuthenticationToken extends AbstractAuthenticationToken {
private static final long serialVersionUID = SpringSecurityCoreVersion.SERIAL_VERSION_UID;
//์ฃผ๋ก ์ฌ์ฉ์ ID์ ํด๋นํจ
private final Object principal;
//์ฃผ๋ก ์ฌ์ฉ์ PW์ ํด๋นํจ
private Object credentials;
//์ธ์ฆ ์๋ฃ ์ ์ ๊ฐ์ฒด ์์ฑ
public UsernamePasswordAuthenticationToken(Object principal, Object credentials) {
super(null);
this.principal = principal;
this.credentials = credentials;
setAuthenticated(false);
}
//์ธ์ฆ ์๋ฃ ํ์ ๊ฐ์ฒด ์์ฑ
public UsernamePasswordAuthenticationToken(Object principal, Object credentials,
Collection<? extends GrantedAuthority> authorities) {
super(authorities);
this.principal = principal;
this.credentials = credentials;
super.setAuthenticated(true); // must use super, as we override
}
}
public abstract class AbstractAuthenticationToken implements Authentication, CredentialsContainer { }
๐ Spring Security๋?
๐ Spring Security์ ๊ฐ๋
- Spring Security ๋ Spring ์ดํ๋ฆฌ์ผ์ด์ ์ ๋ณด์(์ธ์ฆ๊ณผ ๊ถํ ๋ถ์ฌ)์ ๋ด๋นํ๋ ์คํ๋ง์ ํ์ ํ๋ ์์ํฌ์ด๋ค.
- Spring Security๋ ์คํ๋ง์ DispatcherServlet ์๋จ์ Filter ํํ๋ก ์์นํ๋ค.
- Dispatcher๋ก ๋์ด๊ฐ๊ธฐ ์ ์, ์ด Filter๊ฐ ์์ฒญ์ ๊ฐ๋ก์ฑ์ → ํด๋ผ์ด์ธํธ์ ๋ฆฌ์์ค ์ ๊ทผ ๊ถํ์ ํ์ธํ๊ณ → ์๋ ๊ฒฝ์ฐ์๋, ์ธ์ฆ ์์ฒญ ํ๋ฉด์ผ๋ก ์๋ ๋ฆฌ๋ค์ด๋ ํธํ๋ค.
โSpring Security์ ํ์์ฑ
- API์ ๋ํ ๊ถํ ๊ธฐ๋ฅ์ด ์์ผ๋ฉด, ์๋ฌด๋ ํ์ ์ ๋ณด๋ฅผ ์กฐํํ๊ณ ์์ ๋ฐ ์ญ์ ํ ์ ์๋ค.
- ๋ฐ๋ผ์, ์ด๋ฅผ ๋ง๊ธฐ ์ํด ์ธ์ฆ๋ ์ ์ ๋ง API๋ฅผ ์ฌ์ฉํ ์ ์๋๋ก ํด์ผํ๋ฉฐ, ์ธ์ฆ ๋ฐ ๊ถํ ๋ถ์ฌ๋ฅผ ํตํด ๋ฆฌ์์ค ์ฌ์ฉ์ ์ปจํธ๋กค ํ ์ ์๋๋ก ํ๋ ๊ฒ์ Spring Security๊ฐ ์ ๊ณตํ๋ค.
- ์ด๋ฌํ ์ธ์ฆ ๋ฐ ๊ถํ ๊ด๋ฆด ์ํ Java ํ๋ ์์ํฌ์๋ JAAS, Spring Security, Apache Shiro ๋ฑ์ด ์๋ค.
- ๊ทธ๋ ๋ค๋ฉด ์ด๋ค์ ๋นํด ์?! Spring Security๊ฐ ๋ง์ด ์ฌ์ฉ๋๋ ๊ฒ์ผ๊น?!
- Spring Security๋ฅผ ์ฌ์ฉํ๋ฉด, ๋ณด์ ์ฒ๋ฆฌ๋ฅผ ์์ฒด์ ์ผ๋ก ๊ตฌํํ์ง ์์๋ ์ฝ๊ฒ ํ์ํ ๊ธฐ๋ฅ์ ๊ตฌํํ ์ ์๋ค.
๐๏ธ Spring Security์ ๋์ ๊ณผ์
1. ์ฌ์ฉ์ ์ธ์ฆ ์์ฒญ - HTTP ์์ฒญ ์์ (Http Request) ๋ฐ AuthenticationFilter ํต๊ณผ
- Spring Security๋ ์ผ๋ จ์ ํํฐ๋ค์ ๊ฐ์ง๊ณ ์๋ค.
- ์์ฒญ(Request)๋ ์ธ์ฆ(Authentication)๊ณผ ๊ถํ ๋ถ์ฌ(Authorization)์ ์ํด ์ด ํํฐ๋ค์ ํต๊ณผํ๊ฒ ๋๋ค.
- ์ด ํํฐ๋ฅผ ํต๊ณผํ๋ ๊ณผ์ ์, ํด๋น ์์ฒญ๊ณผ ๊ด๋ จ๋ ์ธ์ฆ ํํฐ๋ฅผ ์ฐพ์ ๋๊น์ง ์ง์๋๋ค.
- ์์ฒญ๊ณผ ๊ด๋ จ๋ ์ธ์ฆ ํํฐ : ์ธ์ฆ ๋ฉ์ปค๋์ฆ/๋ชจ๋ธ์ ๊ธฐ๋ฐํ ๊ด๋ จ ํํฐ
- ํํฐ ํต๊ณผ ์์
- HTTP Basic ์ธ์ฆ ์์ฒญ์, BasicAuthenticationFilter ์ ๋๋ฌํ ๋๊น์ง ํํฐ ์ฒด์ธ์ ํต๊ณผํ๋ค.
- HTTP Digest ์ธ์ฆ ์์ฒญ์ DigestAuthenticationFilter ์ ๋๋ฌํ ๋๊น์ง ํํฐ ์ฒด์ธ์ ํต๊ณผํ๋ค.
- ๋ก๊ทธ์ธ form submit ์์ฒญ์ UsernamePasswordAuthenticationFilter ์ ๋๋ฌํ ๋๊น์ง ํํฐ ์ฒด์ธ์ ํต๊ณผํ๋ค.
- X509 ์ธ์ฆ ์์ฒญ์ X509AuthenticationFilter ๋ฑ์ ๋๋ฌํ ๋๊น์ง ํํฐ ์ฒด์ธ์ ํต๊ณผํ๋ค.
- ํํฐ ์ฒด์ธ ์ค ์ธ์ฆ์ ๋ด๋นํ๋ ํํฐ๋ฅผ AuthenticationFilter ๋ผ๊ณ ํ๋ค.
- AuthenticationFilter ๋ ์ฌ์ฉ์์ ์ธ์
ID(JSESSIONID)๊ฐ Security Context ์ ์๋์ง ํ์ธํ๋ค.
- ์ฌ๊ธฐ์, Security Context ๋, ์๋์ ๋ชจ๋ ๋ก์ง์ ํต๊ณผํ ์ธ์ฆ๋ ์ฌ์ฉ์์ ์ ๋ณด(์ธ์ฆ ๊ฐ์ฒด)๋ฅผ ์ ์ฅํ๋ ๊ณต๊ฐ์ด๋ค.
- Security Context์ ์ธ์ ID๊ฐ ์๋ค๋ฉด, ์๋ ๋ก์ง์ ์ํํ๋ค.
- AuthenticationFilter ๋ ์ฌ์ฉ์์ ์ธ์
ID(JSESSIONID)๊ฐ Security Context ์ ์๋์ง ํ์ธํ๋ค.
2. ์ฌ์ฉ์ ์๊ฒฉ ์ฆ๋ช (ID, PW)์ ๊ธฐ๋ฐ์ผ๋ก AuthenticationToken ์์ฑ
- ์ธ์ฆ ์์ฒญ(Request)์ด ๊ด๋ จ AuthenticationFilter ์ ์ํด ์์ ๋๋ฉด, ์์ ๋ ์์ฒญ์์ ์ฌ์ฉ์ ์ด๋ฆ & ๋น๋ฐ๋ฒํธ ๋ฅผ ์ถ์ถํ๋ค.
- ์ถ์ถ๋ ์๊ฒฉ ์ฆ๋ช (credentials)์ ๊ธฐ๋ฐ์ผ๋ก, ์ธ์ฆ ๊ฐ์ฒด๋ฅผ ๋ง๋ค๊ฒ ๋๋๋ฐ, ์ด๋ฅผ UsernamePasswordAuthenticationToken ์ด๋ผ๊ณ ํ๋ค.
3. ์ธ์ฆ์ ์ํด AuthenticationManager์ ์์ฑ๋ AuthenticationToken ์์
- ๋ง๋ค์ด์ง UsernamePasswordAuthenticationToken ์ AuthenticationManager ์ ์ธ์ฆ ๋ฉ์๋๋ฅผ ํธ์ถํ๋๋ฐ ์ฌ์ฉ๋๋ค.
- AuthenticationManager ๋ ๋จ์ํ ์ธํฐํ์ด์ค์ด๋ฉฐ, ์ค์ ๊ตฌํ์ ProviderManager ์ด๋ค.
- ProviderManager ์๋ ์ฌ์ฉ์ ์์ฒญ์ ์ธ์ฆํ๋ ๋ฐ ํ์ํ AuthenticationProvider ๋ชฉ๋ก์ด ์๋ค.
- ProviderManager ๋ ์ ๊ณต๋ ๊ฐ AuthenticationProvider ๋ฅผ ์ดํด๋ณด๊ณ , ์ธ์ฆ๋ ๊ฐ์ฒด(UsernamePasswordAuthenticationToken) ๋ฅผ ๊ธฐ๋ฐ์ผ๋ก ์ฌ์ฉ์ ์ธ์ฆ์ ์๋ํ๋ค.
4. AuthenticationProvider ๋ชฉ๋ก์ผ๋ก ์ธ์ฆ ์๋
- AuthenticationProvider ๋ ์ ๊ณต๋ ์ธ์ฆ ๊ฐ์ฒด๋ก ์ฌ์ฉ์๋ฅผ ์ธ์ฆํ๋ค.
- ํ๋ ์์ํฌ์ ์ ๊ณต๋๋ AuthenticationProvider ์ผ๋ถ
- CasAuthenticationProvider
- Cas(Central Authentication Service) : ์ค์ ์ธ์ฆ ์๋น์ค๋ก, ์น์ฉ ํตํฉ ์ธ์ฆ ํ๋กํ ์ฝ์ด๋ค.
- ์๊ฒฉ ์ ๋ณด๋ฅผ ํ ๋ฒ๋ง ์ ๊ณตํจ์ผ๋ก์จ ์ฌ์ฉ์๊ฐ ์ฌ๋ฌ ์ดํ๋ฆฌ์ผ์ด์ ์ ์ ๊ทผํ ์ ์๋๋ก ํ๋ ๊ฒ์ด ๋ชฉ์
- ์ํธ์ ๊ฐ์ ์ฌ์ฉ์์ ๋ณด์ ์๊ฒฉ ์ ๋ณด์ ์ ๊ทผ ๊ถํ์ ์ ๊ณตํ์ง ์์๋, ์น ์ดํ๋ฆฌ์ผ์ด์ ๋ค์ด ์ฌ์ฉ์๋ฅผ ์ธ์ฆํ ์ ์๋๋ก ํ๋ค.
- Cas(Central Authentication Service) : ์ค์ ์ธ์ฆ ์๋น์ค๋ก, ์น์ฉ ํตํฉ ์ธ์ฆ ํ๋กํ ์ฝ์ด๋ค.
- JaasAuthenticationProvider
- DaoAuthenticationProvider
- OpenIDAuthenticationProvider
- RememberMeAuthenticationProvider
- LdapAuthenticationProvider
- CasAuthenticationProvider
5. PasswordEncoder(๋น๋ฐ๋ฒํธ ์ํธํ ์ธํฐํ์ด์ค) ์์ ํจ์ค์๋ ๋น๊ต
- PasswordEncoder ๋ ํจ์ค์๋ ์ํธํ์ ์ฌ์ฉ๋ PasswordEncoder ๊ตฌํ์ฒด๋ฅผ ์ง์ ํ ์ ์๋ค.
- SpringBoot 2.0 ๋ถํฐ๋ ์ธ์ฆ์ ์ํด์ ๋ฐ๋์ PasswordEncoder ๋ฅผ ์ง์ ํด์ผ ํ๋ค.
- BCryptPasswordEncoder : bcrypt ๋ผ๋ ํด์ ํจ์๋ฅผ ์ด์ฉํด์ ํจ์ค์๋๋ฅผ ์ํธํํ๋ ๋ชฉ์ ์ผ๋ก ์ค๊ณ๋ ํด๋์ค์ด๋ฉฐ, ๋ง์ด ์ฌ์ฉ๋๋ค.
@Bean
public PasswordEncoder passwordEncoder() {
return new BCryptPasswordEncoder();
}
6 ~ 8. ์ฌ์ฉ์ ์ ๋ณด ์ธํฐํ์ด์ค๋ฅผ ํตํด DB์์ ์ฌ์ฉ์ ์ ๋ณด ๋ฐํ
- ์ผ๋ถ AuthenticationProvider ๋ ์ฌ์ฉ์ ์ด๋ฆ(username)์ ๊ธฐ๋ฐ์ผ๋ก ์ฌ์ฉ์ ์ธ๋ถ ์ ๋ณด๋ฅผ ๊ฒ์ํ๊ธฐ ์ํด UserDetailsService ๋ฅผ ์ฌ์ฉํ ์ ์๋ค.
- Ex) DaoAuthenticationProvider
- UserDetailsService ๋ Spring Security ์ ์ธํฐํ์ด์ค์ด๋ฉฐ, ์ด๋ฅผ ๊ตฌํํ ์๋น์ค๋ ์ง์ ๊ฐ๋ฐํด์ผ ํ๋ค.(Customize)
- ์ฆ, ์์ ์ฝ๋์์ loadUserByUsername ๋ฉ์๋๋ฅผ ์ค๋ฒ๋ผ์ด๋ํด DB์ ๋น๊ตํ๋ ****๋ก์ง์ ์ง์ ์ง์ผ ํ๋ ๊ฒ์ด๋ค.
- DB์ ์ฐ๊ฒฐ์ ์ํ VO ๋ก User ๋ฅผ ๊ฐ๋ฐ ํ ์ ์๋ค.
9. ์ธ์ฆ ๊ฐ์ฒด ๋ฐํ ํน์ AuthenticationException ๋ฐ์
- AuthenticationProvider ์ธํฐํ์ด์ค์ ์ํด ์ฌ์ฉ์๊ฐ ์ฑ๊ณต์ ์ผ๋ก ์ธ์ฆ๋๋ฉด → ์์ ํ ์ฑ์์ง ์ธ์ฆ ๊ฐ์ฒด๊ฐ ๋ฐํ๋๋ค.
- ์ธ์ฆ์ ์คํจํ๋ฉด, AuthenticationException ์ด ๋ฐ์ํ๋ค.
- AuthenticationException ์ด ๋ฐ์ํ๋ฉด, ์ธ์ฆ ๋ฉ์ปค๋์ฆ์ ์ง์ํ๋ AuthenticationEntryPoint ์ ์ํด ์ฒ๋ฆฌ๋๋ค.
- AuthenticationEntryPoint ๋, ์ธ์ฆ ๊ณผ์ ์ ์คํจํ๊ฑฐ๋ ์ธ์ฆ ํค๋(Authorization) ๋ฅผ ๋ณด๋ด์ง ์๊ฒ ๋๋ ๊ฒฝ์ฐ → 401(UnAuthorized) ๋ผ๋ ์๋ต๊ฐ์ ๋ฐ๊ฒ๋๋๋ฐ, ์ด๋ฅผ ์ฒ๋ฆฌํ๋ ๋ก์ง์ ์ํํ๋ ์ธํฐํ์ด์ค์ด๋ค.
- AuthenticationException ์ด ๋ฐ์ํ๋ฉด, ์ธ์ฆ ๋ฉ์ปค๋์ฆ์ ์ง์ํ๋ AuthenticationEntryPoint ์ ์ํด ์ฒ๋ฆฌ๋๋ค.
10. ์ธ์ฆ ์๋ฃ
- AuthenticationManager ๋ ํ๋ํ ์์ ํ ์ฑ์์ง ์ธ์ฆ ๊ฐ์ฒด๋ฅผ ๊ด๋ จ ์ธ์ฆ ํํฐ(AuthenticationFilter) ๋ก ๋ค์ ๋ฐํํ๋ค.
11. SecurityContext ์ ์ธ์ฆ ๊ฐ์ฒด ์ค์ (Authentication ์ ์ฅ ๋ฐ ์ธ์ฆ ์๋ฃ ์ฒ๋ฆฌ)
- ๊ด๋ จ AuthenticationFilter ๋ ์ดํ์ ํํฐ ์ฌ์ฉ์ ์ํด ํ๋ํ ์ธ์ฆ ๊ฐ์ฒด๋ฅผ SecurityContext ์ ์ ์ฅํ๋ค.
SecurityContextHolder.getContext().setAuthentication(authentication);
- ์ดํ, SecurityContext ์ ์ธ์ฆ ๊ฐ์ฒด๊ฐ ์๋์ง ํ์ธํ๊ณ → ์ธ์ฆ ๋ก์ง์ด ์ํ๋๊ฑฐ๋ ์ํ๋์ง ์๋๋ค.