"일꾼이 일을 잘하려면 먼저 도구를 갈고 닦아야 한다." - 공자, 『논어』.
첫 장 > 프로그램 작성 > API 디자인의 HTTP 상태 코드에 대한 궁극적인 참조

API 디자인의 HTTP 상태 코드에 대한 궁극적인 참조

2024년 11월 17일에 게시됨
검색:882

The Ultimate Reference for HTTP Status Codes in API Design

웹 개발 및 API 디자인 세계에서 HTTP 상태 코드는 클라이언트와 서버 간의 요청 결과를 전달하는 데 중요한 역할을 합니다. 이러한 코드는 HTTP 요청 처리 중에 발생하는 특정 조건, 성공 또는 오류를 나타내는 표준화된 방법을 제공합니다. 이러한 상태 코드를 이해하는 것은 디버깅, 오류 처리 및 보다 강력한 애플리케이션을 만드는 데 도움이 되므로 개발자에게 필수적입니다.

1. 1xx 정보

이 상태 코드는 임시 응답을 나타냅니다. 실제로는 거의 사용되지 않지만 특정 시나리오에서는 도움이 될 수 있습니다.

  • 100 계속: 서버가 요청 헤더를 수신했으며 클라이언트는 요청 본문 전송을 진행해야 합니다.
  • 101 프로토콜 전환: 요청자가 서버에 프로토콜 전환을 요청했고 서버가 이에 동의했습니다.

2. 2xx 성공

이러한 상태 코드는 클라이언트의 요청이 성공적으로 수신되고 이해되었으며 수락되었음을 나타냅니다.

  • 200 OK: 요청이 성공했으며 응답에 요청한 데이터 또는 결과가 포함되어 있습니다.
    • 예: 사용자의 프로필 정보를 검색합니다.
  • 201 생성됨: 요청이 성공하여 새 리소스가 생성되었습니다.
    • 예: 새 사용자 계정을 만들거나 새 블로그 항목을 게시합니다.
  • 204 콘텐츠 없음: 서버가 요청을 성공적으로 처리했지만 콘텐츠를 반환하지 않습니다.
    • 예: 응답 본문이 필요하지 않은 사용자 설정 업데이트
  • 206 부분 콘텐츠: 클라이언트가 보낸 범위 헤더로 인해 서버가 리소스의 일부만 전달하고 있습니다.
    • 예: 비디오 콘텐츠 스트리밍 또는 대용량 파일을 청크로 다운로드합니다.

3. 3xx 리디렉션

이러한 상태 코드는 요청을 이행하기 위해 사용자 에이전트가 추가 조치를 취해야 함을 나타냅니다.

  • 301 영구적으로 이동됨: 요청된 리소스가 새 URL로 영구적으로 이동되었습니다.
  • 302 발견: 요청한 리소스가 일시적으로 다른 URL에 있습니다.
  • 304 Not Modified: 요청 헤더에 지정된 버전 이후 리소스가 수정되지 않았음을 나타냅니다.

4. 4xx 클라이언트 오류

이러한 상태 코드는 클라이언트가 오류를 범한 것으로 보이는 상황을 위한 것입니다.

  • 400 잘못된 요청: 구문이 잘못되었거나 입력이 잘못되어 서버가 요청을 처리할 수 없습니다.

    • 예: 요청 본문에 잘못된 형식의 JSON을 보냅니다.
    • 사용법: 요청 자체의 형식이 잘못되었거나 잘못된 매개변수가 포함된 경우에 사용합니다.
  • 401 승인되지 않음: 요청에 사용자 인증이 필요합니다.

    • 예: 유효한 자격 증명을 제공하지 않고 보호된 API 엔드포인트에 액세스하려고 시도합니다.
    • 용도: 인증이 필요한데 인증이 제공되지 않았거나 유효하지 않은 경우에 사용합니다.
  • 403 금지됨: 서버가 요청을 이해했지만 승인을 거부했습니다.

    • 예: 관리자 전용 기능에 액세스하려는 사용자입니다.
    • 사용법: 사용자가 인증되었지만 요청한 작업에 대한 권한이 없는 경우에 사용합니다.
  • 404 찾을 수 없음: 요청한 리소스를 서버에서 찾을 수 없습니다.

    • 예: 삭제된 사용자 프로필을 검색하려고 시도합니다.
    • 사용법: 요청한 리소스가 존재하지 않을 때 사용합니다.
  • 405 메서드가 허용되지 않음: 요청에 지정된 메서드는 요청 URI로 식별되는 리소스에 대해 허용되지 않습니다.

    • 예: GET 요청만 허용하는 엔드포인트에 POST 요청을 보냅니다.
  • 409 충돌: 리소스의 현재 상태와 충돌하여 요청을 처리할 수 없습니다.

    • 예: 시스템에 이미 존재하는 이메일로 사용자를 생성하려고 합니다.
    • 사용법: 항목 중복 등 리소스의 현재 상태와 충돌이 있을 때 사용합니다.
  • 422 처리할 수 없는 엔터티: 서버는 요청의 콘텐츠 유형과 구문을 이해하지만 포함된 명령을 처리할 수 없습니다.

    • 예: 서버 측 유효성 검사에 실패한 잘못된 데이터가 포함된 양식을 제출합니다.
    • 사용법: 요청 구문은 정확하지만 데이터가 의미상 잘못된 유효성 검사 오류에 사용됩니다.
  • 429 요청이 너무 많음: 사용자가 주어진 시간 동안 너무 많은 요청을 보냈습니다("속도 제한").

    • 예: 남용을 방지하기 위해 API 속도 제한을 구현합니다.

5. 5xx 서버 오류

이러한 상태 코드는 서버가 오류가 발생했거나 요청을 수행할 수 없음을 인식하는 경우를 나타냅니다.

  • 500 내부 서버 오류: 서버가 요청을 이행하지 못하게 하는 예상치 못한 상황이 발생했음을 나타내는 일반 오류 메시지입니다.

    • 예: 서버측 코드에서 처리되지 않은 예외가 발생합니다.
  • 501 구현되지 않음: 서버가 요청을 이행하는 데 필요한 기능을 지원하지 않습니다.

    • 예: 서버가 인식하지 못하는 새로운 HTTP 방식을 사용하는 경우.
  • 502 잘못된 게이트웨이: 서버가 게이트웨이 또는 프록시 역할을 하는 동안 업스트림 서버로부터 잘못된 응답을 받았습니다.

    • 예: 역방향 프록시 서버가 원본 서버에 연결할 수 없습니다.
  • 503 서비스를 사용할 수 없음: 일시적인 과부하 또는 유지 관리로 인해 서버가 현재 요청을 처리할 수 없습니다.

    • 예: 서버가 예정된 유지 관리를 진행 중이거나 트래픽이 많습니다.
  • 504 게이트웨이 시간 초과: 서버가 게이트웨이 또는 프록시 역할을 하는 동안 업스트림 서버로부터 적시에 응답을 받지 못했습니다.

    • 예: 타사 API의 응답을 기다리는 동안 시간 초과가 발생합니다.

HTTP 상태 코드 사용에 대한 모범 사례

  1. 구체적으로 설명하세요: 상황에 적용되는 가장 구체적인 상태 코드를 사용하세요. 이는 고객이 발생한 일과 대응 방법을 정확히 이해하는 데 도움이 됩니다.

  2. 일관적인 사용: API 전체에서 상태 코드를 사용하는 방법에 있어 일관성을 유지합니다. 이렇게 하면 개발자가 API 작업을 더 쉽게 할 수 있습니다.

  3. 추가 정보 제공: 적절한 경우 상태 코드와 함께 응답 본문에 자세한 오류 메시지를 포함합니다. 이는 디버깅에 도움이 되고 개발자 경험을 향상시킬 수 있습니다.

  4. 보안 고려 사항: 특히 4xx 및 5xx 오류의 경우 오류 응답에서 너무 많은 정보를 공개하지 않도록 주의하세요. 시스템 아키텍처 또는 구현에 대한 민감한 세부 정보를 노출하지 마세요.

  5. 문서화: API가 사용하는 상태 코드와 상황을 명확하게 문서화하세요. 이는 API 소비자가 다양한 응답을 해석하고 처리하는 방법을 이해하는 데 도움이 됩니다.

HTTP 상태 코드를 이해하고 적절하게 구현함으로써 개발자는 더욱 강력하고 명확하며 사용자 친화적인 API 및 웹 애플리케이션을 만들 수 있습니다. 이러한 코드는 클라이언트와 서버 간의 중요한 통신 도구 역할을 하여 오류 처리를 간소화하고 전반적인 시스템 안정성을 향상시키는 데 도움이 됩니다.

릴리스 선언문 이 기사는 https://dev.to/shanu001x/the-ultimate-reference-for-http-status-codes-in-api-design-77b?1에서 복제됩니다. 침해가 있는 경우, Study_golang@163으로 문의하시기 바랍니다. .com에서 삭제하세요
최신 튜토리얼 더>

부인 성명: 제공된 모든 리소스는 부분적으로 인터넷에서 가져온 것입니다. 귀하의 저작권이나 기타 권리 및 이익이 침해된 경우 자세한 이유를 설명하고 저작권 또는 권리 및 이익에 대한 증거를 제공한 후 이메일([email protected])로 보내주십시오. 최대한 빨리 처리해 드리겠습니다.

Copyright© 2022 湘ICP备2022001581号-3