SPRING&BOOT 22

@Query 어노테이션 기본 설명

@Query 어노테이션은 Spring Data JPA에서 JPQL(Java Persistence Query Language) 또는 네이티브 SQL 쿼리를 작성할 때 사용하는 어노테이션이다. 보통은 메서드 이름을 기반으로 쿼리를 자동으로 생성하는데, 복잡한 쿼리나 특정 요구사항이 있는 경우 직접 쿼리를 작성해야 할 때 사용된다. @Query 어노테이션 기본 설명어노테이션 위치: @Query는 Repository 인터페이스의 메서드 위에 붙인다.쿼리 타입: JPQL과 네이티브 쿼리 두 가지를 사용할 수 있다. 기본은 JPQL로, JPA 엔티티를 대상으로 하는 쿼리이다. 네이티브 쿼리는 실제 데이터베이스에서 사용하는 SQL 쿼리를 직접 작성할 수 있다.// 기본 JPQL 예시@Query("SELECT t FR..

SPRING&BOOT/JPA 2024.10.04

Hibernate의 @DynamicInsert와 @DynamicUpdate 정리

데이터베이스와의 효율적인 상호 작용은 현대 애플리케이션 개발에서 중요한 요소입니다. Hibernate는 ORM(Object-Relational Mapping) 프레임워크로, 자바 객체와 데이터베이스 간의 매핑을 간편하게 처리해줍니다. 이 과정에서 Hibernate는 다양한 최적화 기능을 제공하며, 그 중 @DynamicInsert와 @DynamicUpdate는 특히 유용한 어노테이션입니다. 이번 블로그에서는 이 두 어노테이션의 기능과 사용 방법, 언제 사용해야 하는지, 그리고 사용 시 생성되는 SQL 쿼리의 차이점을 상세히 알아보겠습니다. 1. @DynamicInsert는 INSERT 시 동적으로 SQL을 생성하는 기능이다.설명: @DynamicInsert는 엔티티를 저장할 때, null이 아닌 필드만 ..

SPRING&BOOT 2024.09.30

PUT과 PATCH 메서드

웹 개발에서 HTTP 메서드는 클라이언트와 서버 간의 통신을 정의하는 중요한 요소입니다. 그중에서도 PUT과 PATCH는 모두 리소스를 업데이트하는 데 사용되지만, 그 목적과 동작 방식에는 분명한 차이점이 있습니다. 이번 블로그에서는 Spring Boot를 활용하여 PUT과 PATCH의 차이점을 이해하고, 각 메서드를 어떻게 사용해야 하는지 코드 예제와 함께 살펴보겠습니다.1. PUT은 전체 리소스를 대체하는 메서드이다.설명: PUT 메서드는 지정된 리소스를 새로운 데이터로 완전히 대체합니다. 즉, 요청에서 제공된 데이터로 기존 리소스의 모든 내용을 덮어씁니다.사용 상황:리소스의 모든 필드를 업데이트해야 할 때클라이언트가 리소스의 전체 상태를 알고 있으며, 이를 서버에 전달할 때코드 예제:@RestCon..

SPRING&BOOT 2024.09.27

Spring Boot에서 JWT 인증 필터와 ArgumentResolver 활용하기

이번 포스팅에서는 JWT 인증 필터를 설정하고, 이를 통해 인증된 사용자 정보를 컨트롤러로 전달하기 위한 HandlerMethodArgumentResolver 구현 방법을 소개하겠다. Spring Security 없이 커스텀 JWT 필터를 통해 권한과 사용자를 처리하는 구조를 간단하게 설명할 것이다. 1. JWT 인증 필터 (JwtFilter)먼저, 사용자의 요청을 처리하기 전에 JWT 토큰을 검증하는 JwtFilter를 작성하겠다.코드 분석@Slf4j@RequiredArgsConstructorpublic class JwtFilter implements Filter { private final JwtUtil jwtUtil; @Override public void init(FilterCon..

SPRING&BOOT 2024.09.20

AOP(Aspect-Oriented Programming) 개념 및 실습

1. AOP란? **AOP(Aspect-Oriented Programming)**는 코드에서 공통적으로 반복되는 횡단 관심사를 핵심 비즈니스 로직에서 분리하는 프로그래밍 기법이다. AOP를 사용하면 로깅, 트랜잭션 관리, 메서드 실행 시간 측정 등 여러 곳에서 사용되는 부가기능을 한 곳에 모아 관리할 수 있다.2. AOP 용어 정리Aspect(애스팩트): 프로그램에서 반복적으로 필요하지만, 모든 코드에 일일이 넣기 귀찮은 기능들을 한데 묶은 모듈이다. 예를 들어, 로그를 남기거나 보안 처리를 한 곳에 모아서 관리하는 것이라고 보면 된다.Advice(어드바이스): 실제로 실행될 부가기능이다. 예를 들어, 어떤 메소드가 실행될 때 로그를 남기는 구체적인 코드가 어드바이스이다.Pointcut(포인트컷): 어드..

SPRING&BOOT 2024.09.10

CascadeType.REMOVE는 왜 위험할까?

1. cascade = CascadeType.REMOVE란?CascadeType.REMOVE는 JPA에서 사용되는 영속성 관리 옵션 중 하나로, 엔티티 간의 관계에서 부모 엔티티가 삭제될 때, 자식 엔티티도 자동으로 삭제되도록 설정하는 방식이다. 쉽게 말해서 부모-자식 관계가 있는 경우, 부모가 삭제되면 자식도 함께 삭제되는 효과를 주는 옵션이다. @Entitypublic class Order { @OneToMany(mappedBy = "order", cascade = CascadeType.REMOVE) private List orderItems; // getters, setters, etc.}부모 엔티티가 Order이고 자식 엔티티가 OrderItem이라고 하자. Order에 Casca..

SPRING&BOOT/JPA 2024.09.06

필터

스프링 부트에서 필터는 HTTP 요청과 응답을 가로채어 처리할 수 있는 기능이다. 필터를 사용하면 요청이 컨트롤러에 도달하기 전에 사전 처리하거나 응답이 클라이언트에 전달되기 전에 후처리할 수 있다. 필터는 주로 인증, 인가, 로깅, 캐싱 등 다양한 용도로 활용된다.필터란?인증 및 인가: 요청이 특정 리소스에 접근하기 전에 사용자 인증 정보를 확인하거나 권한을 검증하는 데 사용된다. 예를 들어, 로그인 여부를 확인하고, 특정 페이지에 접근 가능한지 검토할 수 있다.로깅: 요청과 응답에 대한 로그를 기록할 수 있다. 요청의 URL, 메소드, 응답 상태 코드 등을 로그로 남기면 문제를 추적하거나 시스템의 동작을 모니터링하는 데 유용하다.성능 최적화: 캐싱 기능을 통해 서버의 성능을 향상시킬 수 있다. 요청에..

SPRING&BOOT 2024.09.03

중간 테이블을 사용하는 이유

중간 테이블(또는 조인 테이블)은 데이터베이스 설계에서 다대다(Many-to-Many) 관계를 표현하기 위해 사용된다. 다대다 관계에서는 두 개의 테이블이 서로 여러 개의 레코드를 가질 수 있는데, 이를 직접적으로 표현하기 어렵기 때문에 중간 테이블을 사용하여 이러한 관계를 관리한다.중간 테이블을 사용하는 이유다대다 관계 표현: 두 테이블 사이의 다대다 관계를 적절하게 표현하기 위해 중간 테이블을 사용한다. 예를 들어, 학생과 수업이라는 두 테이블이 있을 때, 한 학생이 여러 수업에 등록될 수 있고, 하나의 수업에 여러 학생이 등록될 수 있다. 이를 다대다 관계라고 하며, 중간 테이블을 사용하여 이러한 관계를 효율적으로 관리할 수 있다.데이터의 중복 방지: 중간 테이블을 사용하지 않으면, 각 테이블에 중..

SPRING&BOOT/JPA 2024.09.02

JWT란?

JWT(Json Web Token)는 JSON 객체를 사용하여 두 개체 간에 정보를 안전하게 전송하기 위한 웹 표준(RFC 7519)이다. 주로 인증(authentication)과 권한 부여(authorization)에 사용되며, 클라이언트와 서버 간의 안전한 데이터 교환을 위해 설계되었다. JWT는 세션을 서버에 저장하지 않고도 상태를 유지할 수 있게 해주는 토큰 기반 인증 방식으로, RESTful API와 같은 무상태(stateless) 통신에서 널리 활용되고 있다.JWT의 구조JWT는 Header, Payload, Signature의 세 부분으로 구성된 문자열이다. 이 세 부분은 각각 Base64Url로 인코딩되어 마침내 .으로 구분된 하나의 문자열로 결합된다. 이 구조 덕분에 JWT는 가볍고, 웹..

SPRING&BOOT/JPA 2024.08.30

캡슐화(Encapsulation)

캡슐화(Encapsulation)는 객체지향 프로그래밍의 핵심 원칙 중 하나로, 객체의 데이터(필드)와 행위(메서드)를 결합하여 객체 내부에 감추고, 외부에는 필요한 부분만 노출하는 방식을 말한다. 이 포스트에서는 캡슐화가 무엇인지, 왜 중요한지, 그리고 실제 코드 예제를 통해 캡슐화를 어떻게 구현할 수 있는지 상세하게 살펴본다.캡슐화의 정의와 중요성캡슐화는 객체의 상세한 구현 내용을 숨기는 것을 목적으로 한다. 이를 통해 객체의 내부 데이터를 보호하고, 외부의 잘못된 사용으로부터 객체를 보호할 수 있다. 또한, 객체의 사용 방법만을 외부에 노출시키므로, 사용자는 객체가 '무엇'을 할 수 있는지만 알면 되고, 객체가 '어떻게' 그 일을 하는지는 알 필요가 없다. 이런 특성 때문에 캡슐화는 객체지향 설계의..

SPRING&BOOT 2024.08.28