HTTP Status Codes

스머리·2023년 11월 7일

HTTP 상태 코드

클라이언트가 HTTP 메서드 중 하나로 서버에 어떤 요청을 보내면 서버는 이 요청에 대한 응답 결과를 상태 코드와 함께 전달한다. 예를 들어 네이버에서 특정 버튼을 클릭해 요청을 보낸 후 General 헤더 정보를 보면 상태 코드가 함께 전달된 것을 확인할 수 있다.

상태 코드는 HTTP 요청에 대한 응답 결과를 나타낸다.
개발자는 상태 코드를 보고 요청이 성공했는지 혹은 실패했는지 판단하고 처리한다.

상태코드는 5개 그룹으로 나뉜다.

그룹상태 코드설명
1xx정보 응답요청에 대한 처리가 진행 중
2xx성공 응답요청에 대한 응답을 성공적으로 완료
3xx리다이렉션 메시지요청을 완료하기 위해 리다이랙션(새 URL로 재요청)이 필요하다는 의미
4xx클라이언트 오류 응답요청을 처리하던 중 클라이언트 오류 발생
5xx서버 오류 응답클라이언트의 요청을 받았으나 적절히 처리하지 못해 응답할 수 없다는 의미
  • 1xx → 거의 사용하지 않음.

  • 200 OK : 요청 성공

  • 201 Created : 요청 성공해서 새로운 리소스 생성됨. 일반적으로 POST 요청 또는 일부 PUT 요청 이후

  • 202 Accepted : 요청을 수신하였지만 처리가 완료되지 않았음.

    • 예) 요청 접수 후 1시간 뒤 배치 프로세스가 요청 처리
  • 204 No Content : 서버가 요청을 성공적으로 수행했지만, 응답 페이로드 본문에 보낼 데이터가 없음

    • save 버튼의 결과로 아무 내용 없어도 됨. 같은 화면 유지해야 함.
  • 300 Multiple Choices

  • 301 Moved Permanently : 리다이렉트시 요청 메서드가 GET으로 변하고, 본문이 제거될 수 있음

  • 302 Found : 리다이렉트시 요청 메서드가 GET으로 변하고, 본문이 제거될 수 있음(MAY)

  • 303 See Other : 302와 기능은 같음. 리다이렉트시 요청 메서드가 GET으로 변경

  • 304 Not Modified

  • 307 Temporary Redirect : 리다이렉트시 요청 메서드와 본문 유지(요청 메서드를 변경하면 안 된다. MUST NOT)

  • 308 Permanent Redirect : 301과 기능은 같음. 리다이렉트시 요청 메서드와 본문 유지(처음 POST를 보내면 리다이렉트도 POST 유지)

  • 400 Bad Request : 클라이언트가 잘못된 요청을 해서 서버가 요청을 처리할 수 없음

    • 요청 구문, 메시지 등 오류. 요청 내용 다시 컴도하고 보내기
  • 401 Unauthorized : 클라이언트가 해당 리소스에 대한 인증이 필요

  • 403 Forbidden : 서버가 요청을 이해했지만 승인 거부

    • 주로 인증 자격 증명은 있지만, 접근 권한이 불충분
    • 예) 어드민 등급이 아닌 사용자가 로그인은 했지만, 어드민 등급의 리소스에 접근하는 경우
  • 404 Not Found : 요청 리소스를 찾을 수 없음

  • 500 Internal Server Error : 서버 문제로 오류 발생, 애매하면 500 오류

  • 503 Service Unavailable : 서비스 이용 불가

    • 서버가 일시적인 과부하 또는 예정된 작업으로 잠시 요청을 처리할 수 없음

  • 리다이렉션 이해
    • 웹 브라우저는 3xx 응답의 결과에 Location 헤더가 있으면, Location 위치로 자동 이동 (리다이렉트)
    • 종류
      • 영구 리다이렉션 - 특정 리소스의 URI가 영구적으로 이동 (301, 308)
      • 일시 리다이렉션 - 일시적인 변경. 주문 완료 후 주문 내역 화면으로 이동 (302, 307, 303)
        • PRG: Post/Redirect/Get
      • 특수 리다이렉션 - 결과 대신 캐시를 사용
  • 그래서 뭘 써야 하나여? 302, 307, 303
    • 302 Found → GET으로 변할 수 있음
    • 307 Temporary Redirect → 메서드가 변하면 안됨
    • 303 See Other → 메서드가 GET으로 변경
    • 현실
      • 307, 303을 권장하지만 현실적으로 이미 많은 애플리케이션 라이브러리들이 302를 기본값으로 사용
      • 자동 리다이렉션시에 GET으로 변해도 되면 그냥 302를 사용해도 큰 문제 없음

참고

  • 아는 만큼 보이는 프런트엔드 개발
  • 모든 개발자를 위한 HTTP 웹 기본 지식
profile
꾸준히 나아가는 프론트엔드 개발자

0개의 댓글