[Spring] Query Parameter vs Path Variable

2024. 10. 2. 23:51·Back-end/Spring
반응형

결론

자원(데이터)의 위치를 특정해서 보여줘야 할 경우 Path Variable을 쓰고, 정렬하거나 필터해서 보여줘야 할 경우에 Query Parameter를 쓴다. 아래가 바로 그렇게 적용한 사례이다.

/users # Fetch a list of users
/users?occupation=programer # Fetch a list of programer user
/users/123 # Fetch a user who has id 123

 

위의 방식으로 우리는 어디에 어떤 데이터(명사)를 요청하는 것인지 명확하게 정의할 수 있다.

하지만, 그 데이터를 가지고 뭘 하자는 것인지 동사는 빠져있다. 그 동사 역할을 하는 것이 GET, POST, PUT, DELETE 메소드이다.

즉, Query string과 Path variable이 이들 메소드와 결합함으로써 "특정 데이터"에 대한 CRUD 프로세스를 추가의 엔드포인트 없이 완결 지울 수 있게 되는 것인다.
(가령, users/create 혹은 users?action=create를 굳이 명시해 줄 필요가 없다.)

 

/users [GET] # Fetch a list of users
/users [POST] # Create new user
/users/123 [PUT] # Update user
/users/123 [DELETE] # remove user

 

물론 위와 같은 규칙을 지키지 않더라도 잘 돌아가는 API를 만들 수 있다.

하지만 지키지 않을 경우 서비스 엔드포인트는 복잡해 지고, 개발자간/외부와 커뮤니케이션 코스트가 높아져 큰 잠재적 손실을 초래할 수 있으니 이 규칙은 잘 지켜서 사용하는 것이 필수라 하겠다.

 

또한 Path Variable은 여러 개 사용 가능하다.

// project 안에 여러 page가 존재하는 경우
POST /api/project/{projectID}/join/{pageID}
반응형

'Back-end > Spring' 카테고리의 다른 글

[Spring] Spring Boot에서 Google Meet API 적용해보기  (11) 2024.10.06
[Spring] JWT + Redis를 활용한 로그아웃 구현 (Jwt BlackList)  (4) 2024.10.06
[Spring] Security + JWT + Redis를 활용한 로그인 구현 (2)  (0) 2024.08.30
[Spring] @NotNull vs @Column(nullable = false)  (1) 2024.08.19
[Spring] 무한 redirection  (0) 2024.08.14
'Back-end/Spring' 카테고리의 다른 글
  • [Spring] Spring Boot에서 Google Meet API 적용해보기
  • [Spring] JWT + Redis를 활용한 로그아웃 구현 (Jwt BlackList)
  • [Spring] Security + JWT + Redis를 활용한 로그인 구현 (2)
  • [Spring] @NotNull vs @Column(nullable = false)
류건
류건
개발 일지
  • 류건
    건's Dev
    류건
  • 전체
    오늘
    어제
    • 분류 전체보기 (96)
      • Back-end (56)
        • Spring (31)
        • Nest.js (3)
        • Next.js (2)
        • Node.js (3)
      • Infra & Cloud (5)
        • Cloud Computing (6)
        • Docker (3)
        • AWS (7)
      • Java (2)
      • Computer Science (12)
        • Computer Network (0)
        • Operating System (0)
        • 정보 보호와 시스템 보안 (12)
      • 회고록 (1)
        • 우아한테크코스 (3)
  • 블로그 메뉴

    • 홈
    • 태그
    • 방명록
  • 링크

  • 공지사항

  • 인기 글

  • 태그

    보안
    JWT
    public key
    어노테이션
    Nest.js
    ssl
    EC2
    Kafka
    Spring Boot
    express.js
    CI/CD
    Docker
    오블완
    Webflux
    정보보호
    nginx
    티스토리챌린지
    ddl-auto
    node.js
    CORS
    Lock
    고가용성
    WebClient
    CD
    Spring
    aws
    Github Actions
    JPA
    db
    https
  • 최근 댓글

  • 최근 글

  • 반응형
  • hELLO· Designed By정상우.v4.10.0
류건
[Spring] Query Parameter vs Path Variable
상단으로

티스토리툴바