HTTP 메서드의 속성
1. 안전(Safe Methods)
- 호출해도 리소스를 변경하지 않음(단순 조회)
2. 멱등(Idempotent Methods)
- 한 번 호출하던 여러번 호출하던 결과는 같음
- 멱등 메서드
- GET : 한 번 조회하든, 여러번 조회하든 같은 결과가 조회
- PUT : 결과를 대체, 따라서 같은 요청을 여러번 해도 최종 결과는 같음
- DELETE : 결과를 삭제, 따라서 같은 요청을 여러번 해도 삭제된 결과는 같음
- POST : 멱등이 아님, 여러 번 호출하면 같은 결제가 중복해서 발생 가능
- 활용
- 자동 복구 메커니즘
- 서버가 TIMEOUT 등으로 정상 응답을 못주었을 때, 클라이언트가 같은 요청을 다시 해도 되는가의 판단 근거
- 재요청 중간에 다른 곳에서 리소스를 변경해버리면? 멱등은 외부 요인으로 중간에 리소스가 변경되는 것 까지는 고려하지 않음
- A : GET -> username:A, age:20
- B : PUT -> username:A, age:30 (B에 의해 변경됨)
- A : GET -> username:A, age:30
3. 캐시가능(Cacheable)
- 응답 결과 리소스를 캐시해서 사용해도 되는가?
- GET, HEAD, POST, PATCH 캐시 가능
- 실제로는 GET, HEAD 정도만 캐시로 사용
- POST, PATCH는 본문 내용까지 캐시 키로 고려해야 하는데, 구현이 쉽지 않음
(REF.인프런)