쿠릉쿠릉 쾅쾅
쿠릉쿠릉 쾅쾅
쿠릉쿠릉 쾅쾅
250x250
전체 방문자
오늘
어제
  • 분류 전체보기
    • HTML CSS
    • 잡담
    • 프로그래밍 꿀팁 사이트
    • 코딩 도서
    • [자바]
      • 디자인 패턴
      • 자바의 정석 - 3판
      • 자바
      • 자바 문법
    • git
    • [TDD]
    • 개발 서적 독후감
      • 클린 코더
      • 토비 스프링3
      • 객체지향의 사실과 오해
      • 모던 자바 인 액션
      • 엘레강트 오브젝트
    • CS
      • 운영체제
      • HTTP
    • [SQL]
      • SQL 기초
      • 혼자공부하는SQL
    • [ Spring ]
      • REST API
      • Spring Toy
      • Spring 에러
      • Spring
      • Spring 입문
      • Spring 핵심 원리
      • SpringMVC 1편
      • SpringMVC 2편
      • Spring Boot를 이용한 RESTful We..
      • Batch
    • [JPA]
      • JPA
      • JPA 에러
      • JPA 프로그래밍 - 기본편
      • 스프링 부트와 JPA 활용 1 - 웹 애플리케이..
      • 실전! 스프링 부트와 JPA 활용2 - API 개..
      • 실전! 스프링 데이터 JPA
      • 실전! Querydsl
    • 인텔리제이
    • [DB]
      • DB
      • H2
    • Gradle
    • 면접
    • [알고리즘]
      • 알고리즘
      • 자료구조
      • 자바 알고리즘 공부
    • [프로젝트]
    • 쿠릉식 객체지향 사고
    • 리눅스

블로그 메뉴

  • 홈
  • 태그
  • 방명록

공지사항

인기 글

태그

  • querydsl
  • 자바
  • springboot
  • GitHub
  • 알고리즘
  • http
  • JPA
  • 깃허브
  • Git
  • 백준
  • Spring
  • 재귀
  • 스프링부트
  • 스프링
  • 자료구조
  • MVC
  • SQL
  • 함수형인터페이스
  • REST API
  • java

최근 댓글

최근 글

티스토리

hELLO · Designed By 정상우.
쿠릉쿠릉 쾅쾅

쿠릉쿠릉 쾅쾅

[Spring] API 구현을 위한 Hateoas 적용
[ Spring ]/REST API

[Spring] API 구현을 위한 Hateoas 적용

2022. 5. 10. 18:10
728x90

 

 

Hateoas

Hateoas는 Hypermedia As The Engine Of Application State의 약자다.
하이퍼미디어를 애플리케이션의 상태를 관리하기 위한 매커니즘으로 사용한다.
Hateoas는 Rest Api를 사용되는 클라이언트가 서버와 동적인 상호작용을 가능케한다.
클라이언트가 서버에게 요청을 할 때, 요청에 필요한 URI를 응답에 포함시켜서 반환한다.
예를 들어, 사용자 정보를 생성(POST)하는 요청 이후, 이를 조회, 수정, 삭제할 때, 이러한 모든 동작을 URI를 이용해 동적으로 알려준다는 의미입니다.

Hateoas는 REST API를 잘 설계하기 위해 나온 개념이다.
REST API는 웹 애플리케이션이 제공하는 데이터를 리소스, 즉 자원으로 간주하고 각각의 자원에 고유한 URI를 할당함으로써 이를 표현하는 API를 정의하기 위한 소프트웨어 아키텍처 스타일이다.

Hateoas 공식 문서 : https://docs.spring.io/spring-hateoas/docs/current/reference/html/#reference

잘 설계된 REST API는 구현하기 위한 단계가 존재한다.

REST 구현 단계

1단계 :  리소스 도입
- 서버가 가진 모든 데이터를 하나의 자원으로 관리하며 고유한 URI를 제공함으로써 클라이언트가 하나의 단일 API 엔트포인트가 아닌 각 자원과 직접 커뮤니케이션을 할 수 있도록 한다.
2단계 : HTTP 동사
- HTTP 동사를 이용하여 자원에 대해 수행하고자 하는 작업의 종류를 표현한다.
3번 : 하이퍼미디어 컨트롤
- Hateoas라는 개념을 통해 해당 자원에 대한 호출 가능한 API에 대한 정보를 자원 상태를 반영하여 표현한다. 자원 상태에 따라 서버가 클라이언트에게 동적으로 정보를 제공할 수 있다.

 

 

마지막 단계가 Hypermedia Controls (하이퍼미디어 컨트롤) - Hateoas 개념을 통해 자원에 호출 가능한 API 정보를 자원의 상태를 반영하여 표현한 것이다.

REST API 구현 단계별 예시

Hateoas 사용 전 / 후 비교

Hateoas 사용 전
Hateoas 사용 후

Hateoas를 사용하면 클라이언트 사이드에서 'rel'의 이름으로 요청 URI를 사용하기 때문에 URI를 수정해도 클라이언트 사이드 수정이 이뤄지지 않는다.

 

Hateos 사용 예시

📌 User

@Data
@AllArgsConstructor
@NoArgsConstructor
public class User {

    private Long id;

    @Size(min = 2, message = "Name은 2글자 이상 입력해 주세요.")
    private String name;

    @Past  // 과거 날짜만 가능하도록 제약
    private LocalDateTime joinDate;

    private String password;
    private String ssn; // 주민등록번호

}

📌 UserController

@RestController
@RequiredArgsConstructor
public class UserController {

    private final UserDaoService service;

    @GetMapping("/users")
    public List<User> retrieveAllUsers() {
        return service.findAll();
    }

    @GetMapping("/users/{id}")
    public EntityModel<User> retrieveUser(@PathVariable Long id) {
        Optional<User> userOptional = service.findOne(id);

        if (userOptional.isEmpty()) {
            throw new UserNotFoundException(String.format("ID[%s] not found", id));
        }

        User findUser = userOptional.orElse(null);

        // HATEOAS
        EntityModel<User> model = EntityModel.of(findUser);
        // 링크 생성
        WebMvcLinkBuilder linkTo = WebMvcLinkBuilder.linkTo(
                WebMvcLinkBuilder.methodOn(this.getClass()).retrieveAllUsers());
        // 링크 추가
        model.add(linkTo.withRel("all-users"));

        return model;
    }

    ...


}

EntityModel<T>

  • 도메인 객체를 감싸고 그 외 링크를 추가하는 객체다.
  • add() : 링크 추가 메서드

WebMvcLinkBuilder.linkTo() :  컨트롤 클래스를 가리키는 WebMvcLinkBuilder 객체를 반환한다.
WebMvcLinkBuilder.methodOn() : 타겟 메서드의 가짜 메서드 콜이 들어있는 컨트롤러 프록시 클래스를 생성한다. 직접 메서드 객체를 만드는 것보다 유연한 표현이 가능하다.

 

 

 

 


👀 참고 자료

https://joomn11.tistory.com/26

 

[Hateoas] Hateoas(헤이티오스) 란 ( + REST API란 )

Hateoas에 대한 정의 REST API에 대한 정의 Hateoas 사용 예시 Hateoas에 대한 정의 Hypermedia As The Engine Of Application State의 약자로, 기본적인 아이디어는 하이퍼미디어를 애플리케이션의 상태를 관..

joomn11.tistory.com

 

https://kkambi.tistory.com/126

 

[spring] 스프링 부트의 Hateoas 지원

Hateoas? Hypermedia As The Engine Of Application State - REST 아키텍쳐의 구성 요소 - REST API에서 리소스를 제공할 때, 연관된 링크 정보를 함께 제공 - 클라이언트는 연관 링크 정보를 바탕으로 리소스에..

kkambi.tistory.com

 

https://m.blog.naver.com/tmondev/220391644590

 

Hypermedia-driven REST API

지난 수 년에 걸쳐 웹 개발 패러다임은 지속적인 변화를 겪어왔습니다. 그 중에서도 가장 제 관심을 끈 변...

blog.naver.com

 

728x90

'[ Spring ] > REST API' 카테고리의 다른 글

[Spring] Rest Api Monitoring을 위한 Actuator 설정  (0) 2022.05.11
[Spring] Rest API Documentation을 위한 Swagger 사용  (0) 2022.05.10
[Spring] Rest Api Version 관리  (0) 2022.05.10
[Spring] Response 데이터 제어를 위한 Filtering  (0) 2022.05.09
[Spring] AOP를 이용한 Exception Handing  (0) 2022.05.08
    '[ Spring ]/REST API' 카테고리의 다른 글
    • [Spring] Rest Api Monitoring을 위한 Actuator 설정
    • [Spring] Rest API Documentation을 위한 Swagger 사용
    • [Spring] Rest Api Version 관리
    • [Spring] Response 데이터 제어를 위한 Filtering
    쿠릉쿠릉 쾅쾅
    쿠릉쿠릉 쾅쾅
    깃허브 주소 : https://github.com/kureung

    티스토리툴바