강의

멘토링

커뮤니티

인프런 커뮤니티 질문&답변

유승현님의 프로필 이미지
유승현

작성한 질문수

스프링 MVC 1편 - 백엔드 웹 개발 핵심 기술

요청 매핑 - API 예시

HTTP RESTAPI 경로에 식별자 관련

작성

·

283

1

HTTP API 경로에 entity의 식별자를 넣어 사용하는게 추세라고 하셨는데 

--------

@GetMapping("users/{userId}/posts/{postId}")

라고 할때, mvc2 강의에서 user의 정보는 탈취 당하고 악용될 수 잇으므로 session 을 통해 user의 info를 받아와 사용한다고 말씀하셨습니다

------

그러면 user에 대한 경로는 다 없애고 session을 통해 정보를 받아와서 사용하고 그 외 다른것은 저렇게 식별자를 통해서 사용해서 api 경로를 매핑하면 될까요?

REST API case에서 자신이 등록한 게시글만 조회하는 api의 경우

-----

@GetMapping("/posts/{postId}")

public post(HttpSession session, @PathVariable Long postId){

Long userId = (Long) session.getAttribute(LOGIN_ACCOUNT);

}

이런식으로 사용하면 될까요?

-------

추가적으로 위처럼 적용한다고 하면, 자신이 등록한 post를 api 조회하는 경로와, 전체 post에서 어떤 post를 조회하는 api의 경로가 같게 되는데
여기서 또 문제가 있는 것 같습니다.

위 처럼 사용시  

자신이 등록한 post들 전체 조회 api => "/posts"

전체 post 조회 api 또한 => "/posts"

어떤 방식으로 접근하는게 좋은지 답변주시면 감사드리겠습니다.

답변 1

0

안녕하세요. 유승현님, 공식 서포터즈 David입니다.

.
1. user의 식별자를 없애시고 말씀하신대로 작성하셔서 사용하시면 됩니다.

2. API 경로는 겹치지 않게 설계해야 합니다. 자신이 등록한 글 모두를 조회하는 것이라면 /user/posts 정도로 정의하여 사용할 수 있습니다.

Rest API 설계 방법에 대해 찾아보시면 API를 정의하는데 도움이 되실 것 같습니다.

https://sanghaklee.tistory.com/57
.
감사합니다.

유승현님의 프로필 이미지
유승현

작성한 질문수

질문하기