Amazon S3 정적 웹 사이트 기능을 사용할 때 액세스 거부 오류가 발생하는 이유는 무엇입니까?

5분 분량
0

Amazon Simple Storage Service(Amazon S3) 버킷을 사용하여 S3 정적 웹 사이트 엔드포인트가 포함된 정적 웹 사이트를 호스팅할 때 액세스 거부 오류가 발생하는 이유를 알고 싶습니다.

해결 방법

Amazon S3를 사용하여 정적 웹 사이트를 호스팅하려고 하는데 Access Denied 오류가 발생하는 경우 다음 요구 사항을 확인하십시오.

버킷의 객체를 공개적으로 액세스할 수 있음

S3 정적 웹 사이트 엔드포인트는 공개적으로 액세스할 수 있는 콘텐츠만 지원합니다. S3 버킷의 객체에 공개적으로 액세스할 수 있는지 확인하려면 웹 브라우저에서 객체의 URL을 여십시오. 또는 URL에서 cURL 명령을 실행할 수 있습니다.

다음은 S3 객체 URL의 예입니다.

http://doc-example-bucket.s3-website-us-east-1.amazonaws.com/index.html

웹 브라우저 또는 curl 명령에서 Access Denied 오류가 반환되는 경우 객체가 공개적으로 액세스할 수 없습니다. S3 객체에 대한 퍼블릭 읽기 액세스를 허용하려면 버킷의 모든 객체에 대한 퍼블릭 읽기 액세스를 허용하는 버킷 정책을 생성하십시오.

S3 버킷 정책이 s3:GetObject에 대한 액세스를 허용해야 합니다.

버킷 정책을 검토하고 s3:GetObject 작업에 대한 퍼블릭 읽기 액세스를 차단하는 거부 명령문이 없는지 확인하십시오. 버킷 정책에 s3:GetObject에 대한 명시적 허용문이 있더라도 명시적 거부문과 충돌하지 않는지 확인하십시오. 명시적 거부문은 항상 명시적 허용문보다 우선합니다.

s3:GetObject에 대한 버킷 정책을 검토하려면 다음 단계를 수행하십시오.

  1. Amazon S3 콘솔을 엽니다.
  2. 권한 탭을 선택합니다.
  3. 버킷 정책을 선택합니다.
  4. 버킷 정책에서 **"Action": "s3:GetObject" 또는 "Action": "s3:*"**가 포함된 명령문을 검토합니다.
  5. (선택 사항) 버킷 정책을 수정합니다. 예를 들어 s3:GetObject에 대한 퍼블릭 읽기 액세스를 차단하는 명령문을 제거하거나 편집할 수 있습니다.

버킷을 소유한 AWS 계정이 객체도 소유해야 합니다.

객체에 대한 퍼블릭 읽기 액세스를 허용하려면, 버킷을 소유한 AWS 계정이 객체도 소유해야 합니다. 버킷 또는 객체는 버킷 또는 객체를 생성한 AWS Identity and Access Management(IAM) ID 계정이 소유합니다.

참고: 객체 소유권 요구 사항은 버킷 정책에서 부여한 퍼블릭 읽기 권한에 적용됩니다. 이는 객체의 액세스 제어 목록(ACL)에서 부여한 퍼블릭 읽기 권한에는 적용되지 않습니다.

Amazon S3 버킷과 객체를 동일한 AWS 계정에서 소유하고 있는지 확인하려면 다음 단계를 수행하십시오.

  1. 버킷 소유자의 S3 표준 ID를 검색하려면 다음 명령을 사용합니다.

    aws s3api list-buckets --query Owner.ID
  2. 객체 소유자의 S3 표준 ID를 검색하려면 다음 명령을 사용합니다.

    aws s3api list-objects --bucket DOC-EXAMPLE-BUCKET --prefix index.html

    참고: 이 예는 단일 객체를 보여 줍니다. 여러 객체를 검사하려면 list 명령을 사용하십시오.

  3. 버킷 소유자와 객체 소유자의 표준 ID가 일치하는지 확인합니다. 일치하지 않으면 버킷과 객체의 소유자가 다른 것입니다.
    참고: Amazon S3 콘솔을 사용해도 버킷 및 객체 소유자를 확인할 수 있습니다. 소유자는 해당 버킷 또는 객체의 권한 탭에서 확인할 수 있습니다.

  4. 버킷과 객체 소유자의 표준 ID가 일치하지 않는 경우 객체 소유자를 버킷 소유자로 변경하십시오.
    객체 소유자 계정에서 다음 명령을 실행하여 객체에 할당된 ACL 권한을 검색합니다.

    aws s3api get-object-acl --bucket DOC-EXAMPLE-BUCKET --key object-name

    객체에 버킷 소유자 전체 제어 ACL 권한이 없는 경우 객체 소유자 계정에서 다음 명령을 실행합니다.

    aws s3api put-object-acl --bucket DOC-EXAMPLE-BUCKET --key object-name --acl bucket-owner-full-control

    객체에 bucket-owner-full-control ACL 권한이 있는 경우 버킷 소유자 계정에서 다음 명령을 실행합니다. 이 명령은 객체를 복사하여 객체 소유자를 변경합니다.

    aws s3 cp s3://DOC-EXAMPLE-BUCKET/index.html s3://DOC-EXAMPLE-BUCKET/index.html --storage-class STANDARD

    또한 S3 객체 소유권을 사용하여 익명 사용자나 다른 AWS 계정이 업로드한 객체의 자동 소유권을 버킷 소유자에게 부여할 수 있습니다.

버킷의 객체는 AWS KMS로 암호화할 수 없습니다.

AWS KMS는 익명 요청을 지원하지 않습니다. 따라서 익명 또는 퍼블릭 액세스를 허용하는 Amazon S3 버킷은 AWS KMS로 암호화된 객체에 적용되지 않습니다. Amazon S3 정적 웹 사이트 엔드포인트를 사용하여 서비스하려는 객체에서 KMS 암호화를 제거해야 합니다.

참고: AWS KMS 암호화 대신 AES-256 을 사용하여 객체를 암호화하십시오.

다음 방법을 사용하여 버킷의 객체가 KMS로 암호화되었는지 확인할 수 있습니다.

  • Amazon S3 콘솔을 사용하여 객체의 속성을 봅니다. 암호화 대화 상자를 검토합니다. AWS KMS를 선택한 경우 객체는 KMS로 암호화됩니다.
  • AWS Command Line Interface(AWS CLI)를 사용하여 head-object 명령을 실행합니다. 명령이 ServerSideEncryption을 aws:kms로 반환하면 객체는 KMS로 암호화됩니다.

참고: AWS CLI 명령을 실행할 때 오류가 발생하면 최신 AWS CLI 버전을 사용하고 있는지 확인하십시오.

Amazon S3 콘솔을 사용하여 객체의 암호화 설정을 변경하려면 Amazon S3 암호화 지정을 참조하십시오.

AWS CLI를 사용하여 객체의 암호화 설정을 변경하려면 객체 버킷에 기본 암호화가 없는지 확인하십시오. 버킷에 기본 암호화가 없는 경우 객체를 복사하여 객체의 암호화를 제거합니다.

aws s3 cp s3://DOC-EXAMPLE-BUCKET/index.html s3://DOC-EXAMPLE-BUCKET/index.html --storage-class STANDARD

경고: 객체 자체를 복사하면 storage-classwebsite-redirect-location에 대한 설정이 제거됩니다. 새 객체에서 이러한 설정을 유지하려면 복사 요청에서 storage-class 또는 website-redirect-location 값을 명시적으로 지정해야 합니다.

요청된 객체는 S3 버킷에 있어야 합니다.

요청을 수행하는 사용자에게 s3:ListBucket 권한이 없는 경우 누락된 개체에 대해 Access Denied 오류가 발생합니다.

head-object AWS CLI 명령을 실행하여 버킷에 객체가 있는지 확인할 수 있습니다.

참고: S3 객체 이름은 대소문자를 구분합니다. 요청에 유효한 객체 이름이 없는 경우 Amazon S3는 객체가 누락되었다고 보고합니다.

객체가 버킷에 있는 경우 Access Denied 오류는 404 Not Found 오류를 가리지 않습니다. Access Denied 오류를 해결하려면 다른 구성 요구 사항을 확인하십시오.

객체가 버킷에 없는 경우 Access Denied 오류가 404 Not Found 오류를 가리는 것입니다. 누락된 객체와 관련된 문제를 해결하십시오.

참고: 퍼블릭 s3:ListBucket 액세스를 활성화하는 것은 보안 모범 사례가 아닙니다. 퍼블릭 s3:ListBucket 액세스를 활성화하면 사용자가 버킷의 모든 객체를 보고 나열할 수 있습니다. 이 액세스는 사용자에게 객체 다운로드 권한이 없더라도 객체 메타데이터 세부 정보(예: 키 및 크기)를 사용자에게 노출합니다.

Amazon S3 Block Public Access를 버킷에서 비활성화해야 합니다.

Amazon S3 Block Public Access 설정은 개별 버킷 또는 AWS 계정에 적용할 수 있습니다. S3 버킷 또는 AWS 계정Amazon S3 Block Public Access 설정이 적용되지 않았는지 확인하십시오. 이러한 설정은 퍼블릭 읽기 액세스를 허용하는 권한을 무시할 수 있습니다.

AWS 공식
AWS 공식업데이트됨 6달 전