AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / server / 问题 / 923731
Accepted
Tom Brossman
Tom Brossman
Asked: 2018-07-27 13:53:33 +0800 CST2018-07-27 13:53:33 +0800 CST 2018-07-27 13:53:33 +0800 CST

如何限制 S3 对象仅访问 CloudFront?

  • 772

TL;DR - 如何https://s3-eu-west-1.amazonaws.com/BUCKET-NAME/FILE.EXT在允许来自 CloudFront 的请求的同时阻止请求?

我遵循了 AWS 文档“ Restricting Access to Amazon S3 Content by Using an Origin Access Identity ”,这似乎已经过测试并且工作得几乎完美(在我的情况下使用备用域名集),但是当我尝试使用 URL 时......

https://s3-eu-west-1.amazonaws.com/BUCKET-NAME/index.html

...返回 index.html 文档!更糟糕的是,我可以按照这个约定访问存储桶中的任何对象。我的理解是这不应该发生,只有 CloudFront URL 应该返回对象。

S3 存储桶的静态网站托管已禁用。访问 S3 端点 URL 会http://BUCKET-NAME.s3-website-eu-west-1.amazonaws.com/index.html返回 404(代码为“NoSuchWebsiteConfiguration”),这是预期的结果。有人可以解释为什么其他链接有效,而不是返回 403 或 404 错误吗?

当我设置 CloudFront 分配时,对于“授予对存储桶的读取权限”选项,我选择了“是,更新存储桶策略”,这产生了现在使用的 S3 存储桶策略:

{
  "Version": "2008-10-17",
  "Id": "PolicyForCloudFrontPrivateContent",
  "Statement": [
    {
      "Sid": " Grant a CloudFront Origin Identity access to support private content",
      "Effect": "Allow",
      "Principal": {
        "AWS": "arn:aws:iam::cloudfront:user/CloudFront Origin Access Identity XXXXXXXXXXXXXX"
      },
      "Action": "s3:GetObject",
      "Resource": "arn:aws:s3:::BUCKET-NAME/*"
    }
  ]
}
amazon-web-services
  • 1 1 个回答
  • 1862 Views

1 个回答

  • Voted
  1. Best Answer
    Michael - sqlbot
    2018-07-27T15:24:26+08:002018-07-27T15:24:26+08:00

    如果您在上传对象时将对象设置为公开(或随后设置为公开),这将是预期的结果。如果它们是公开的,那么它们就是公开的,所以 S3 允许它们被访问。

    原始访问身份实际上并不“限制访问”。它们允许通过 CloudFront 访问非公共对象。

    您引用的文档页面中提到了这一点。

    更改您的 Amazon S3 存储桶或存储桶中的对象的权限,以便只有源访问身份具有读取权限(或读取和下载权限)。

    这话不好说。这就是它的实际含义。

    如果您已授予任何权限(通过存储桶策略对您的 Amazon S3 存储桶、通过对象 ACL 对您的存储桶中的对象或两者)以允许公共访问,则必须首先删除所有此类权限,然后再删除存储桶策略语句然后必须创建,以便 OAI 具有对对象的读取访问权限。

    • 2

相关问题

  • 与 AWS 中的其他系统相比,CentOS 报告的总内存较低

  • 如何在 Amazon Linux 服务器上升级到 Java 1.8?

  • 了解 Amazon AWS 使用数据

  • 亚马逊提供的负载均衡服务体验如何?

  • ELB 中现有节点的 AWS 自动缩放问题

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    新安装后 postgres 的默认超级用户用户名/密码是什么?

    • 5 个回答
  • Marko Smith

    SFTP 使用什么端口?

    • 6 个回答
  • Marko Smith

    命令行列出 Windows Active Directory 组中的用户?

    • 9 个回答
  • Marko Smith

    什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同?

    • 3 个回答
  • Marko Smith

    如何确定bash变量是否为空?

    • 15 个回答
  • Martin Hope
    Tom Feiner 如何按大小对 du -h 输出进行排序 2009-02-26 05:42:42 +0800 CST
  • Martin Hope
    Noah Goodrich 什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同? 2009-05-19 18:24:42 +0800 CST
  • Martin Hope
    Brent 如何确定bash变量是否为空? 2009-05-13 09:54:48 +0800 CST
  • Martin Hope
    cletus 您如何找到在 Windows 中打开文件的进程? 2009-05-01 16:47:16 +0800 CST

热门标签

linux nginx windows networking ubuntu domain-name-system amazon-web-services active-directory apache-2.4 ssh

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve