티스토리 뷰

HTTP 로고

 

 

 

 

HTTP 상태코드

 

HTTP Status Code(= HTTP 상태 코드)는 서버에서 설정해주는 응답 정보입니다.

그래서 네트워크 통신을 하여 상태코드를 분석하여 어떤 종류의 오류가 났는지 어떤 행동을 할 것인지에 대한 지표가 됩니다.

 

응답 상태 코드

 

 

 

 

2xx 상태 코드

 

200번대의 상태 코드는 대부분 성공을 의미합니다.

 

  • 200 : OK (성공)
    요청에 대한 성공, 보통 GET 요청에 대한 성공 응답으로 사용된다.
  • 201 : Created (생성 됨)
    요청에 대한 리소스 생성완료, 보통 POST 요청을 처리하고 새롭게 DB or 파일이 생성된 경우 사용된다.
  • 202 : Accepted (수락 됨)
    요청이 접수되었으나 아직 처리가 완료되지 않음, 비동기적인 작업을 수행할 때 사용된다.
  • 204 : No Content (내용 없음)
    요청에 성공했으나 응답 본문에 데이터가 없음, 주로 DELETE 요청과 같이 리소스가 삭제되었을 때 사용된다.
  • 205 : Reset Content (콘텐츠 재설정)
    요청 성공했으나 클라이언트의 화면을 새로 고침또는 다른 페이지로 이동 하도록 권고
  • 206 : Partial Content (부분 내용)
    요청 성공했으나 일부 범위의 데이터만 반환, 대용량 파일 다운로드 등에서 요청 범위에 따른 부분적인 응답을 보낼 때 사용된다.

 

 

 

 

3xx 상태 코드

 

300번대의 상태 코드는 대부분  리다이렉션과 관련된 상태를 의미합니다.

 

  • 301 : Moved Permanently (영구적으로 이동함)
    요청한 리소스가 새로운 위치로 영구적으로 이동한 경우에 반환됩니다. 클라이언트는 이후에 요청 시 새 위치로 이동해야합니다.
    예를 들어, /old-page에 위치한 페이지가 /new-page로 이동 했을 때, 서버는 301 코드와 함께 새 위치를 알려줍니다.
    redirect시 요청 메소드가 GET으로 변하고, 본문이 제거될 수 있다.
  • 302 : Found (임시로 이동함)
    리소스가 임시적으로 다른 위치로 이동했을 때 반환됩니다.
    예를 들어, 웹 사이트 점검 중일 때, 서버는 임시적으로 유지 보수 페이지로 리다이렉션할 수 있습니다.
    리다이렉트시 요청 메소드가 GET으로 변하고, 본문이 제거될 수 있다.
  • 303 : See Other (다른 곳을 참조함)
    302와 유사하지만, 클라이언트의 요청에 대한 응답으로 새 리소스가 생성되었거나 다른 위치로 리다이렉션될 때 사용됩니다.
    예를 들어, 사용자가 로그인 양식을 제출한 후, 서버는 POST 요청을 처리하고 새로운 페이지로 리다이렉션하여 사용자가 계속하여 정보를 제출하지 않도록 할 수 있습니다.
    주로 POST 요청의 결과를 GET 요청으로 확인할 때 사용된다. 메서드가 GET으로 바뀌기 때문에
  • 304 : Not Modified (수정되지 않음)
    클라이언트의 조건부 GET 요청에 대한 응답으로, 요청한 리소스가 수정되지 않았음을 나타냅니다.
    클라이언트는 캐시된 버전을 계속 사용할 수 있습니다.
    예를 들어, 사용자가 이미 방문한 웹 페이지를 요청할 때, 서버는 리소스가 수정되지 않았으므로 클라이언트의 캐시된 버전을 사용하도록 합니다.
  • 307 : Temporary Redirect (임시 리다이렉트)
    302와 유사하지만, 클라이언트는 요청 시 원래 위치를 계속 사용해야합니다. 
    예를 들어, 웹 애플리케이션에서 로그인 후 사용자를 대시보드 페이지로 임시 리다이렉트할 때 사용합니다.
    redirect시 요청 메서드와 본문을 변하지 않고 리다이렉트될 수 있습니다.
  • 308 : Permanent Redirect (영구 리다이렉트)
    301과 유사하지만, 클라이언트는 요청 시 새로운 위치를 사용해야 합니다. 
    예를 들어, 사용자가 온라인 쇼핑 카드에서 결제를 완료한 후, 영구 리다이렉트를 통해 주문 확인 페이지로 이동할 때 사용합니다.
    redirect시 요청 메서드와 본문을 유지한 채 리다이렉트 될 수 있습니다.

 

 

 

 

4xx 상태코드

 

400번대의 상태 코드는 대부분 클라이언트의 잘못된 요청이나 부적절한 요청으로 발생되는 경우입니다.

 

  • 400 : Bad Request (잘못된 요청)
    클라이언트의 요청이 부적절하거나 유효하지 않은 경우
    예를 들어, 요청의 구문 오타나 필수 요청 매개변수의 누락인 경우에 발생된다.
  • 401 : Unauthorized (인증되지 않음)
    클라이언트가 해당 리소스에 대한 인증이 필요한 경우
    예를 들어, 로그인이 안되어 있는데 리소스에 접근할라는 경우에 발생된다.
  • 403 : Forbidden (접근 금지)
    클라이언트가 요청한 자원에 대한 접근 권한이 없는 경우
    예를 들어, 로그인은 된 상태지만 관리자가 아닌 일반 유저라서 시스템 설정에는 못들어 갈 때 발생됩니다.
  • 404 : Not Found (찾을 수 없음)
    요청한 자원이 서버에 없다.
  • 405 : Method Not Allowed (허용되지 않는 메서드)
    클라이언트가 요청한 HTTP 메서드가 서버에서 허용되지 않는 경우
    예를 들어, API URI는 동일하고 GET메서드로 되어있는데 POST로 호출할 경우
  • 409 : Conflict (충돌)
    서버의 현재 상태와 충돌이 발생하여 요청이 처리되지 않았을 경우
    예를 들어, 동시에 여러 클라이언트가 동일한 리소스를 수정하려고 할 때 발생된다.

 

 

 

 

5xx 상태 코드

 

500번대의 상태 코드는 대부분 서버 쪽에서 오류가 난 경우입니다.

 

  • 500 : Internal Server Error (내부 서버 오류)
    서버 내부에서 오류가 발생한 경우, 기본 오류 거의 이 상태 코드로 보여진다.
  • 501 : Not Implemented (구현되지 않음)
    클라이언트가 요청한 동작이 서버에 구현되지 않은 경우, 서버가 요청한 동작을 수행할 수 없을 때 나타냅니다.
    예를 들어, 클라이언트가 지원하지 않는 HTTP 메서드를 요청한 경우 사용된다.
  • 502 : Bad Gateway (잘못된 게이트웨이)
    서버가 다른 서버로부터 올바른 응답을 받지 못한 경우, 서버가 게이트웨이 or 프록시 역할을 하는 다른 서버로부터 유효한 응답을 받지 못했을 때 나타냅니다.
    예를 들어, 게이트웨이 or 프록시 서버의 장애 또는 설정 문제로 인해 발생된다.
  • 503 : Service Unavailable (서비스 사용 불가)
    서버가 일시적으로 과부하 상태 또는 서버가 유지보수로 인해 내려간 경우
  • 504 : Gateway TimeOut (게이트웨이 시간 초과)
    서버가 게이트웨이 역할을 하고 있으며 적시에 응답을 받을 수 없을 경우, 응답을 제한 시간 내에 못받은 경우에 발생되거나 연결 지연으로 발생된다.

 

 

 

 

감사합니다.

 

 

 

 

공지사항
최근에 올라온 글
최근에 달린 댓글
Total
Today
Yesterday
링크
«   2024/12   »
1 2 3 4 5 6 7
8 9 10 11 12 13 14
15 16 17 18 19 20 21
22 23 24 25 26 27 28
29 30 31
글 보관함