api 결과에 대한 질문
298
작성한 질문수 22
restapi로 댓글 crud를 할때에 대한 질문입니다. (crud 모두 restapi로 구현하였습니다.)
create, update, delete에 대한 결과값으로 return new ResponseEntity<>(200); 을 하게 만들었습니다. 그리고 성공하면 클라이언트가 댓글리스트를 가져오는 api를 요청하도록 만들었습니다. 이렇게 만드는 게 맞는 건가요?
ResponseEntity를 리턴하는 컨트롤러의 경우 @RestController말고 @Controller를 달아도 되던데, @RestController로 명시적으로 해주는 게 맞을가요?
자신이 쓴 댓글에는 수정 및 삭제를 보이게 하고 싶습니다. 다양한 방식이 있던데 일반적으로는 어떤 방식으로 하는지 궁금합니다.
답변 1
0
안녕하세요, 인프런 AI 인턴이에요.
먼저, create, update, delete에 대한 결과값으로 new ResponseEntity<>(200)를 return하는 것은 좋은 방법이에요. 성공적으로 처리되었음을 나타내는 Http Status Code 200을 리턴해 줌으로써 클라이언트 측에서 처리 결과를 쉽게 확인할 수 있게 되어요.
그리고 ResponseEntity를 리턴하는 컨트롤러에는 @RestController 어노테이션을 사용하는 것이 명시적이고 권장되는 방법이에요. @RestController 어노테이션은 @Controller 어노테이션과는 달리 @ResponseBody 어노테이션이 필요 없으므로 코드가 간결해지고, RESTful한 API를 구현하기 용이해져요.
마지막으로, 자신이 쓴 댓글에 대해서는 일반적으로 해당 댓글을 수정하거나 삭제하는 버튼이 보이도록 하는게 일반적이에요. 클라이언트 측에서 API를 불러와 댓글 리스트를 보여주는 부분에 해당 버튼을 추가하면 좋아요. 이를 위해 클라이언트 측에서는 자신이 쓴 댓글인지 판단하는 기준을 정하고, 서버 측에서는 해당 유저인 경우에만 수정 및 삭제에 대한 권한을 부여하게끔 만들면 됩니다.
답변이 도움이 되었길 바랍니다. 감사합니다.
어드바이스 순서 디폴트 기준이 궁금합니다.
0
55
1
AspectV1 예제를 @Configuration 수동 등록으로도 가능한가요?
0
81
2
구체 클래스를 상속받아 확장한 형태도 클래스패턴/데코레이터 패턴이라고 칭하나요?
0
57
1
TraceTemplate 을 미리 빈으로 등록해서 사용할때 이렇게 설정하는게 맞는건가요?
0
54
1
Decorator 에서 추상메서드로 뺄때 질문 있습니다.
0
56
1
대상 클래스에 기본 생성자가 없을 때
0
76
1
스프링 부트 버전 4.0 aop 의존성 명칭 변경
1
362
2
final 키워드 사용 관련 질문
0
78
1
안녕하세요
0
65
1
ThradLocal 실무 사례
0
98
2
실무에서의 동시성 문제
0
64
1
로그 등 부가 기능에 대한 테스트코드
0
50
1
ProceedingJoinPoint와 MethodInvocation에 대하여
0
67
1
실무 멀티스레딩에 대한 궁금증
0
70
1
안녕하세요 질문있습니다
0
45
1
AspectV3 aop 실행 순서 문의 드립니다
0
38
1
MDC vs AOP 중에 고민중입니다.
0
76
1
순환참조
0
161
2
this를 단독으로 사용할때랑 파라미터 바인딩 할때 차이
0
78
1
빈 후처리에 등록 질문 있습니다.
0
77
1
AppConfig 설정하는 설명중에 이해가 안되는게 있습니다.
0
90
1
ThreadLocal을 지역변수로 선언하면 remove가 필요할까요?
0
118
2
@Aspect 어노테이션으로 생성된 Advisor의 Bean 저장 여부
0
69
1
ThreadLocal 사용시 부작용이 있을수 있을까요? (ThreadLocal.remove()를 잘한다고 해도..)
0
73
2





