안녕하세요. rkskqksk님
HTTP API와 REST API는 사실 거의 같은 의미로 사용됩니다.
그런데 디테일하게 들어가면 차이가 있습니다.
HTTP API는 HTTP를 사용해서 서로 정해둔 스펙으로 데이터를 주고 받으며 통신하는 것으로 이해하시면 됩니다.
그래서 상당히 넓은 의미로 사용됩니다.
반면에 REST API는 HTTP API에 여러가지 제약 조건이 추가됩니다.
REST는 다음 4가지 제약조건을 만족해야 합니다.
(https://ko.wikipedia.org/wiki/REST)
- 자원의 식별
- 메시지를 통한 리소스 조작
- 자기서술적 메서지
- 애플리케이션의 상태에 대한 엔진으로서 하이퍼미디어
여러가지가 있지만 대표적으로 구현하기 어려운 부분이 마지막에 있는 부분인데요. 이것은 HTML처럼 하이퍼링크가 추가되어서 다음에 어떤 API를 호출해야 하는지를 해당 링크를 통해서 받을 수 있어야 합니다.
그리고 이런 부분을 완벽하게 지키면서 개발하는 것을 RESTful API라고 하는데요. 실무에서 이런 방법으로 개발하는 것은 현실적으로 어렵고, 또 추가 개발 비용대비 효과가 있는 것도 아닙니다.
그런데 이미 많은 사람들이 해당 조건을 지키지 않아도 REST API라고 하기 때문에, HTTP API나 REST API를 거의 같은 의미로 사용하고 있습니다. 하지만 앞서 말씀드린 것 처럼 엄격하게 위의 내용들을 모두 지켜야 REST API라고 할 수 있습니다.(하지만 다들 HTTP API를 REST API라고 이미 하고 있기 때문에, 누군가 REST API라고 하면 그냥 아~ HTTP API를 이야기 하는구나 라고 생각하고 들으시면 됩니다. 물론 엄격하게는 다릅니다.)
도움이 되셨길 바래요.
출처 : https://www.inflearn.com/questions/126743
Http로 통신하는 packet에는 Header가 붙어 있음. Body의 Data의 형식마다 Header에 Body가 어떤 Data인지 다르게 정의 해야하는 것이 MIME타입
사용자가 요청 -> 응답 (HTML 파일)
@Controller
@Controller
public class MemberController {
private final MemberService memberService;
@GetMapping("/members/new")
public String createForm(){
return "members/createMemberForm";
}
...
return 값이 [기본경로값]/members/createMemberForm.html 파일의 내용을 반환해줌
사용자가 요청 -> 응답 (Data)
@RestController
ex)
@RestController
public class HttpControllerTest {
private static final String TAG="HttpControllerTest : ";
@GetMapping("/http/get")
public String getTest(Member m) {
System.out.println(TAG+"getter : " +m.getId());
m.setId(5000);
System.out.println(TAG+"setter : " +m.getId());
return "get 요청 : " + m.getId()+ ", "+ m.getUsername() + ", "+ m.getEmail() + ", "+ m.getPassword();
}
return값이 String(Data)그대로 반환됨
'무지성 메모' 카테고리의 다른 글
■ @RequestBody는 언제 붙여야 하는가 ■ @Transactional 더티체킹? ■ x-www form-urlencoded json 차이 (0) | 2022.03.07 |
---|---|
■ yaml파일이란 무엇인가..? (.yml) (0) | 2022.03.04 |
■ Git은 3가지 박스를 동기화하는 작업 ■ UTF-8 간단 설명 (0) | 2022.02.28 |
■ 스프링 IoC(제어의 역전) (0) | 2022.02.28 |
■ list의 요소 수정하기 (0) | 2022.02.27 |