Amazon S3 存储桶策略仅允许访问特定的 http

问题描述 投票:0回答:2

我尝试使用存储桶策略将对 Amazon S3 存储桶中的对象(媒体文件)的访问限制为特定的引用域

privatewebsite.com
,但无论引用的域如何,访问都会被拒绝。

我有以下阻止公共访问设置

阻止对通过新访问控制列表 (ACL) 授予的存储桶和对象的公共访问 - 开

阻止对通过任何访问控制列表 (ACL) 授予的存储桶和对象的公共访问 - 开

阻止对通过新公共存储桶策略授予的存储桶和对象的公共访问 - 关闭

通过任何公共存储桶策略阻止对存储桶和对象的公共和跨账户访问 - 关闭

我添加了以下代码、带或不带 URL、http:// 和 https://,但访问仍然被拒绝。 (privatewebsite.com,https://privatewebsite.comhttp://privatewebsite.com

{
    "Version": "2012-10-17",
    "Id": "Policy8675309",
    "Statement": [
        {
            "Sid": "Stmt8675309",
            "Effect": "Allow",
            "Principal": "*",
            "Action": "s3:GetObject",
            "Resource": "arn:aws:s3:::my-media-bucket/*",
            "Condition": {
                "StringLike": {
                    "aws:Referer": "https://privatewebsite.com"
                }
            }
        },
        {
            "Sid": "Explicit deny to ensure requests are allowed only from specific referer.",
            "Effect": "Deny",
            "Principal": "*",
            "Action": "s3:*",
            "Resource": "arn:aws:s3:::my-media-bucket/*",
            "Condition": {
                "StringNotLike": {
                    "aws:Referer": [
                        "https://privatewebsite.com/*",
                        "http://privatewebsite.com/*"
                    ]
                }
            }
        }
    ]
}

任何人都可以看到我的存储桶策略中存在任何明显错误吗?

我希望此策略允许来自 privatewebsite.com 上的页面的任何请求,同时拒绝所有其他请求,但目前所有请求都被拒绝。

json amazon-web-services amazon-s3
2个回答
8
投票

来自存储桶策略示例 - 限制对特定 HTTP Referrer 的访问

{
    "Version": "2012-10-17",
    "Id": "http referer policy example",
    "Statement": [
        {
            "Sid": "Allow get requests originating from www.example.com and example.com.",
            "Effect": "Allow",
            "Principal": "*",
            "Action": "s3:GetObject",
            "Resource": "arn:aws:s3:::examplebucket/*",
            "Condition": {
                "StringLike": {
                    "aws:Referer": [
                        "http://www.example.com/*",
                        "http://example.com/*"
                    ]
                }
            }
        }
    ]
}

此方法仅授予给定 Referer 的

Allow
访问权限。无需使用
Deny
策略,因为默认情况下会拒绝访问。因此,仅授予
Allow
权限。


1
投票

为您尝试一下类似字符串的部分(允许部分):

        "StringLike": {
            "aws:Referer": [
                "https://privatewebsite.com/*",
                "http://privatewebsite.com/*"
            ]
        }
© www.soinside.com 2019 - 2024. All rights reserved.