Spring 129

[Spring Boot] 2-10. Core Features: Auto-Configuration

Spring Boot에서 제공하는 Starter 모듈을 의존성으로 사용하면, 관련 객체의 Auto-Configuration 라이브러리가 함께 제공됩니다.Spring Boot는 Auto-Configuration 라이브러리를 픽업하여 자동 설정을 적용합니다. 1. Understanding Auto-configured Beans항목설명@AutoConfigure* 어노테이션관련 자동 설정을 활성화하는 역할 (마커 어노테이션)자동설정 클래스 네이밍*AutoConfiguration 패턴을 따르며, 클래스에 @AutoConfiguration 어노테이션이 붙음자동설정 활성화 방식자동설정 클래스의 메서드를 실행하여 관련 설정을 자동 적용Bean 등록각 메서드는 관련된 컴포넌트를 @Bean으로 등록함조건부 설정 제어 어노..

Spring/Spring Boot 2023.10.11

[Spring Boot] 2-6. Core Features: JSON

1. Jackson항목설명기본 제공Spring Boot는 spring-boot-starter-json을 통해 Jackson을 기본 JSON 직렬화 도구로 사용자동 설정Spring Boot의 Auto-Configuration에 의해 ObjectMapper가 자동 설정됨핵심 클래스ObjectMapper: 직렬화/역직렬화의 중심 클래스 Custom Serializers and Deserializers@JsonComponent항목설명정의커스텀 Serializer/Deserializer를 빈으로 자동 등록ObjectMapper에 등록됨특징내부 클래스 형태로 JsonSerializer, JsonDeserializer 구현 가능메타 정보@Component가 메타 어노테이션으로 포함되어 있음 예시) 커스텀 JsonS..

Spring/Spring Boot 2023.10.09

[Spring Boot] 2-3. Core Features: Profile

profile은 애플리케이션의 설정을 분리하여 특정 프로파일에 필요한 환경설정을 제공할 수 있습니다.@Profile 어노테이션을 통해 해당 클래스가 어떤 profile에 적용될지 가리킬 수 있습니다.어떤 프로파일을 활성화할지 명시할 수 있습니다.property : spring.profiles.active command line args : --spring.profiles.active 기본 프로파일을 명시할 수 있습니다.property : spring.profiles.default프로파일 활성화 조건을 명시할 수 있습니다.property : spring.config.activate.on-profile 1. Adding Active Profilesspring.profiles.active 프로퍼티는 Prope..

Spring/Spring Boot 2023.10.09

[Spring Boot] 2-2. Core Features: Externalized Configuration

1. Command Line Properties항목설명정의SpringApplication은 명령행 인자(Command Line Arguments)를 PropertySource로 변환해 Environment에 추가함우선순위매우 높음 → .properties, .yml, 환경 변수보다 우선 적용됨오버라이드 여부명령행 인자가 동일 키의 다른 설정들을 오버라이드함비활성화 방법SpringApplication.setAddCommandLineProperties(false)를 호출하면 Environment에 추가되지 않음$ java -jar app.jar --server.port=8085 2. JSON Application Properties항목설명정의JSON 문자열로 애플리케이션 설정을 주입하는 방식사용 키spri..

Spring/Spring Boot 2023.10.09

[Spring Boot] 2-1. Core Features: SpringApplication 클래스

0. SpringApplicationSpringApplication 클래스는 Spring application을 편리하게 기동하는 방법을 제공하는 클래스입니다.SpringApplication.run 메서드가 main method로부터 호출되어 bootstrapping 작업을 시작합니다.startup과 연관된 메시지가 출력됩니다. (INFO 레벨의 로그) 1. Startup FailureFaliureAnalyzerspring Boot 기동중 에러 발생 시 문제 해결을 담당합니다.여러 에러에 대해 다양한 구현체를 가지고 있습니다.에러 메시지를 출력합니다. ConditionEvaluationReport 어떤 자동 설정이 적용되었고 제외되었는지 그리고 그 이유가 무엇인지를 DEBUG 레벨 로그로 출력해주는 객..

Spring/Spring Boot 2023.10.08

[Spring Boot] 1-2. Spring Boot 사용하기

6. Using the @SpringBootApplication Annotation간편하게 auto-configuration을 사용할 수 있도록 지원하는 메타 어노테이션입니다. 코드) @SpringBootApplication더보기더보기@Target(ElementType.TYPE)@Retention(RetentionPolicy.RUNTIME)@Documented@Inherited@SpringBootConfiguration@EnableAutoConfiguration@ComponentScan(excludeFilters = { @Filter(type = FilterType.CUSTOM, classes = TypeExcludeFilter.class), @Filter(type = FilterType.CUSTO..

Spring/Spring Boot 2023.10.07

[Spring Boot] 1-1. Spring Boot 사용하기

1. Build SystemSpring Boot는 의존성 관리를 위한 build system을 선택하여 사용할 수 있습니다. build system은 repository에 있는 공개된 artifact들을 가져오는 기능을 지원합니다.Spring Boot에서는 Maven, Gradle이 자주 사용됩니다.Ant, lvy 등도 지원되지만 기능이 제한되어 있습니다. Dependency Management각 Spring Boot 버전별로 사용하는 의존성의 버전을 큐레이션 해 두었습니다.각 Spring Boot 버전은 특정 Spring 버전을 바탕으로 두고 있습니다.Spring Boot 버전이 올라가면 해당 버전의 적절한 의존성 버전이 제공됩니다.사용자는 Spring Boot 버전별 의존성에 대한 버전을 따로 지정하..

Spring/Spring Boot 2023.10.07

[Spring Security] 5-1. 보안: CSRF

1. CSRF 공격이란?위조된 사이트에서 클릭을 통해 사용자가 의도하지 않은 요청을 특정 사이트로 전송하는 공격입니다.공격자가 피해자의 웹 브라우저를 통해 웹 사이트에 대한 위조된 요청을 생성하는 공격입니다.의도하지 않은 요청에 대한 인증은 브라우저의 쿠키정보를 사용하여 통과합니다.사용자의 쿠키정보가 브라우저에 남아있는 점을 이용합니다. example사용자가 은행 웹사이트에서 이체 거래를 마쳤습니다.사용자는 메일 확인중, 모르는 자로부터 링크가 담긴 메일을 받았습니다.사용자는 경각심없이 메일의 링크를 클릭하였습니다.링크를 통해 이동한 웹 페이지에는 클릭만 하면 상품을 준다는 버튼이 있었습니다.사용자는 클릭을 하였습니다.이 버튼은 이전에 사용자가 사용했던 은행 웹사이트로 송금을 요청하는 버튼이었습니다.송금..

[Spring Security][KoLiving] 4-5. BlackList Token

BlacklistToken 시스템은 AccessToken의 보안 취약성을 보완하는 방법입니다.AccessToken은 짧은 유효기간으로 설정되도록 설계되어 탈취되더라도 오랫동안 사용할 수 없습니다.그러나 그 기간동안 악의적인 공격자로 인해 피해를 받는 것은 사실이며 짧은 기간내에도 큰 피해를 줄 수 있습니다.이러한 위험으로부터 보호하기 위해 유효하지 않은 AccessToken를 무효화하기 위해 도입되었습니다. 1. 인증 시 검증 절차로 확인@Slf4j@RequiredArgsConstructorpublic class JwtAuthenticationFilter extends OncePerRequestFilter { private final JwtProvider jwtProvider; private ..

[Spring Security][KoLiving] 4-4. RefreshToken Rotation

* 이전 포스팅의 시리즈입니다. 3. RefreshToken Rotation클라이언트가 RefreshToken를 통해 AccessToken를 새로 발급받을 경우 RefreshToken도 함께 새로 발급해주는 방식RefreshToken 의 보안 취약점을 최소화하는 기법입니다.만약 RefreshToken가 탈취되었다면, 서버는 RefreshToken 사용자가 악의적인 사용자인지 식별할 수 없습니다.RefreshToken Rotation은 이러한 취약점을 보완하고자 도입되었습니다.만약 AccessToken을 요청할 때마다 RefreshToken을 새로 발급하게 되면공격자가 RefreshToken를 새로 발급 받고 사용자가 이전 RefreshToken로 AccessToken를 요청할 경우서버에 저장된 Refre..