일시적인 리다이렉션
302, 307, 303
- 리소스의 URI가 일시적으로 변경
- 따라서 검색 엔진 등에서 URL을 변경하면 안 됨
- 302 Found
- 리다이렉트시 요청 메서드가 GET으로 변하고, 본문이 제거될 수 있음
- 307 Temporary Redirect
- 302와 기능은 같음
- 리다이렉트시 요청 메서드와 본문 유지(요청 메서드를 변경하면 안 된다.)
- 303 See Other
- 302와 기능은 같음
- 리다이렉트시 요청 메서드가 GET으로 변경
PRG : Post/Redirect/Get
일시적인 리다이렉션 - 예시
- POST로 주문 후에 웹 브라우저를 새로고침 하면?
- 새로고침은 다시 요청
- 중복 주문이 될 수 있다.
PRG: 사용 전
1. 주문 페이지에서 mouse 1개 구입 요청
2. 주문 DB 저장
3. 정상 응답
4. 주문 완료 후 새로고침
5. 이전 요청 (1) 재요청
6. 주문 DB 저장
7. 정상 응답
일시적인 리다이렉션 - 예시
- POST로 주문 후에 새로고침으로 인한 중복 주문 방지
- POST로 주문 후에 주문 결과 화면을 GET 메서드로 리다이렉트
- 새로고침해도 결과 화면을 GET으로 조회
- 중복 주문 대신에 결과 화면만 GET으로 다시 요청
PRG : Post/Redirect/Get
1. 주문 페이지에서 mouse 1개 구입 요청
2. 주문 DB 저장
3. 302 코드를 통해 Location: /order-result/19 (결제 내역 페이지) 리다이렉트
4. 자동 리다이렉트
5. 302 코드로 인해 GET 메서드를 사용하며 /order-result/19 요청
6. 주문 데이터 조회
7. 정상 응답
8. 새로고침시 이전 요청이었던 5번부터 수행
그래서 무엇을 써야 할까?
302, 307, 303
- 정리
- 302 Found > GET으로 변할 수 있음
- 307 Temporary Redirect > 메서드가 변하면 안 됨
- 303 See Other > 메서드가 GET으로 변경
- 역사
- 처음 302 스펙의 의도는 HTTP 메서드를 유지하는 것
- 그런데 웹 브라우저들이 대부분 GET으로 바꾸어버림 (일부는 다르게 동작)
- 그래서 모호한 302를 대신하는 명확한 307, 303이 등장함 (301 대응으로 308도 등장)
- 현실
- 307, 303을 권장하지만 현실적으로 이미 많은 애플리케이션 라이브러리들이 302를 기본값으로 사용
- 자동 리다이렉션시에 GET으로 변해도 되면 그냥 302를 사용해도 큰 문제없음
기타 리다이렉션
300, 304
- 300 Multiple Choices : 안 씀
- 304 Not Modified
- 캐시를 목적으로 사용
- 클라이언트에게 리소스가 수정되지 않았음을 알려준다. 따라서 클라이언트는 로컬 PC에 저장된 캐시를 재사용 (캐시로 리다이렉트)
- 304 응답은 응답에 메시지 바디를 포함하면 안 된다. (로컬 캐시를 사용해야 하므로)
- 조건부 GET, HEAD 요청 시 사용
출처 : https://www.inflearn.com/course/http-%EC%9B%B9-%EB%84%A4%ED%8A%B8%EC%9B%8C%ED%81%AC
'HTTP > HTTP 상태코드' 카테고리의 다른 글
[HTTP] HTTP 상태코드 - 4xx, 5xx (클라이언트, 서버 오류) (0) | 2023.01.20 |
---|---|
[HTTP] HTTP 상태코드 - 3xx (리다이렉션) (1) (0) | 2023.01.20 |
[HTTP] HTTP 상태코드 - 2xx (성공) (0) | 2023.01.20 |
[HTTP] HTTP 상태코드 (0) | 2023.01.20 |