🔙 Backend/🌿 Springboot

    Spring Boot :: @FeignClient 로 외부 REST API 간편 호출

    Spring Boot :: @FeignClient 로 외부 REST API 간편 호출

    들어가면서 카카오 및 애플 로그인을 구현하면서 외부 API 서버에 접근해 데이터를 받아와야 하는 일이 많아졌고, API 주소를 설정파일에 저장한 후 직접 HttpURLConnection 을 생성해서 연결하는 코드가 중복되게 되었다. 또 직접 HttpURLConnection 을 연결해 외부 API 에서 데이터를 받아오면 받아온 JSON 을 직접 파싱해야 하는 불편함도 존재했다. 정리하자면, 외부 API 를 간편하게 호출하고 싶어서 호출 결과를 직접 파싱하는 과정이 번거로워서 FeignClient 를 사용하게 되었다. 아래 설명에서는 많이 예시를 드는 Github API 를 이용해서 코드를 작성해보았다. FeinClient Feign 은 Netflix 에서 개발한 REST Client 이다. 기존에 Rest..

    JUnit :: ParameterizedTest 로 경계값 테스트하기

    JUnit :: ParameterizedTest 로 경계값 테스트하기

    경계값에서 장애가 많이 일어난다 테스트할 때는 input 값의 경계값에 대해서 항상 테스트를 진행해야 한다 그러기 위해 ParameterizedTest 를 이용하면 여러 데이터 소스를 사용할 수 있다. build.gradle 수정 junit-jupiter-params 추가 testImplementation 'org.junit.jupiter:junit-jupiter-params:5.8.2' 자세한 내용은 아래 링크 참조 https://www.petrikainulainen.net/programming/testing/junit-5-tutorial-writing-parameterized-tests/ 실습 비밀번호 입력 값 검증 테스트 요구사항 비밀번호는 최소 8자 이상 12자 이하여야 한다. 비밀번호가 8자 미..

    JPA :: 벌크성 수정 쿼리

    JPA :: 벌크성 수정 쿼리

    벌크 연산 여러 건의 데이터를 한 번에 수정하거나 삭제 조건에 맞는 객체를 다 가지고 와서 수정할 필요 없이 DB 쿼리로 해결하는 것. JPA Bulk 예제 코드 : 파라미터로 받은 나이보다 많은 회원들의 나이를 +1 시킨다. public int bulkAgePlus(int age) { return em.createQuery( "update Member m set m.age = m.age + 1" + " where m.age >= :age") .setParameter("age", age) .executeUpdate(); } 테스트 코드 @Test public void bulkUpdate() { //given memberJpaRepository.save(new Member("member1", 10)); m..

    JPA :: 페이징과 정렬

    JPA :: 페이징과 정렬

    기존 JPA 페이징과 정렬 public List findByPage(int age, int offset, int limit) { return em.createQuery("select m from Member m where m.age = :age order by m.username desc") .setParameter("age", age) .setFirstResult(offset) .setMaxResults(limit) .getResultList(); } public long totalCount(int age) { return em.createQuery("select count(m) from Member m where m.age = :age", Long.class) .setParameter("age", a..

    JPA :: Query Method 기능

    JPA :: Query Method 기능

    스프링 데이터 JPA 가 제공하는 마법같은 기능이 있다. 바로 “쿼리 메소드” 기능인데, 결론부터 말하면 3가지 기능이 있다. 메소드 이름으로 쿼리 생성 메소드 이름으로 JPA NamedQuery 호출 @Query 어노테이션을 사용해서 Repository interface 에 쿼리 직접 정의 Method 이름으로 Query 생성 메소드 이름을 분석해서 JPQL 쿼리 실행 예) 이름과 나이를 기준으로 회원을 조회하려면 ? // 순수 JPA Repository public List findByUsernameAndAgeGreaterThan(String username, int age) { return em.createQuery("select m from Member m where m.username = :us..

    Spring Boot :: Spring Data 패키지 구조

    Spring Boot :: Spring Data 패키지 구조

    Spring Data JPA 를 활용해서 인터페이스를 사용할 때 JpaRepository 를 상속받아서 사용한다. 이 JpaRepository 안에 들어가면 또 다른 Repository 를 상속받고 또 상속받고 ,, 이 구조에 대해서 기록해두고자 한다. 인터페이스 살펴보기 먼저 MemberRepository 라는 레포지토리를 만들어보았다. public interface MemberRepository extends JpaRepository { } 여기서 JpaRepository 안에 들어가보자. 패키지 위치는 org.springframework.data.jpa.repository 이다. JpaRepository 는 PagingAndSortingRepository 를 상속받고 있고, PagingAndSort..

    Spring Boot :: Spring Data JPA

    Spring Boot :: Spring Data JPA

    인터페이스만 정의해도 CRUD 기능을 사용할 수 있다 ? 테스트 코드를 통해서 CRUD 기능이 동작하는지 간단하게 테스트해보자. 테스트 순서 Entity 생성 순수 JPA Repository 생성 후 테스트 Data JPA Repository 생성 후 테스트 Entity 생성 먼저 Member Entity 를 만들자. @Entity @Getter @Setter @NoArgsConstructor(access = AccessLevel.PROTECTED) @ToString(of = {"id", "username"}) public class Member { @Id @GeneratedValue @Column(name = "member_id") private Long id; private String usernam..

    JPA :: Auditing 엔티티 공통 정보 추가하기

    JPA :: Auditing 엔티티 공통 정보 추가하기

    Auditing JPA 에서 도메인을 RDB 테이블에 매핑할 때, 도메인들이 공통으로 가지고 있는 필드들 존재 생성일자, 수정일자, 생성자, 수정자 등 JPA 에서 Audit 기능 제공 Spring Data JPA 에서 시간 값을 자동으로 넣어줌 Auditing 예시 코드 build.gradle 에 의존성 추가 dependency { implementation 'org.springframework.boot:spring-boot-starter-data-jpa' } 스프링 부트에서 gradle 로 의존성을 관리한다면 spring-boot-starter-data-jpa 만 추가해주면 된다. BaseTimeEntity.java @Getter @MappedSuperclass @EntityListeners(Audi..