> 웹 프론트엔드 > JS 튜토리얼 > API 디자인의 HTTP 상태 코드에 대한 궁극적인 참조

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

WBOY
풀어 주다: 2024-08-24 11:04:02
원래의
693명이 탐색했습니다.

The Ultimate Reference for HTTP Status Codes in API Design

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

1. 1xx 정보

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

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

2. 2xx 성공

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

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

3. 3xx 리디렉션

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

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

4. 4xx 클라이언트 오류

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

  • 400 Bad Request: 잘못된 구문이나 잘못된 입력으로 인해 서버가 요청을 처리할 수 없습니다.

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

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

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

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

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

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

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

    • 예: 남용 방지를 위해 API 속도 제한 구현

5. 5xx 서버 오류

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

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

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

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

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

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

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

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

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

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

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

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

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

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

위 내용은 API 디자인의 HTTP 상태 코드에 대한 궁극적인 참조의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:dev.to
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿