我像这样配置了我的 s3 设置:
DEFAULT_FILE_STORAGE = 'Bonychicken.storage_backends.MediaStorage'
AWS_STORAGE_BUCKET_NAME = 'bonychicken'
AWS_S3_REGION_NAME = 'us-east-2'
AWS_ACCESS_KEY_ID = '<my access key id>'
AWS_SECRET_ACCESS_KEY = '<my secret access key>'
AWS_S3_CUSTOM_DOMAIN = f"{AWS_STORAGE_BUCKET_NAME}.s3.{AWS_S3_REGION_NAME}.amazonaws.com"
AWS_QUERYSTRING_AUTH = False
AWS_DEFAULT_ACL = None
STATIC_URL = '/static/'
MEDIAFILES_LOCATION = 'media'
MEDIA_URL = f"https://{AWS_S3_CUSTOM_DOMAIN}/media/"
MEDIA_ROOT = f"https://{AWS_S3_CUSTOM_DOMAIN}/media/"
AWS_IS_GZIPPED = True
AWS_S3_OBJECT_PARAMETERS = {
'CacheControl': 'max-age=86400',
}
我的存储类是:
from storages.backends.s3boto3 import S3Boto3Storage
class MediaStorage(S3Boto3Storage):
bucket_name = 'bonychicken'
location = 'media'
file_overwrite = False
我添加storages
到我已安装的应用程序并且boto3
也已安装。
CORS 配置为:
<?xml version="1.0" encoding="UTF-8"?>
<CORSConfiguration xmlns="http://s3.amazonaws.com/doc/2006-03-01/">
<CORSRule>
<AllowedOrigin>*</AllowedOrigin>
<AllowedMethod>GET</AllowedMethod>
<MaxAgeSeconds>3000</MaxAgeSeconds>
<AllowedHeader>Authorization</AllowedHeader>
</CORSRule>
</CORSConfiguration>
block public access
已关闭。
IAM
用户拥有存储桶的权限。
问题是,每当我上传文件时,它都会上传到我的 s3 存储桶,但它不会显示在 html 页面上。尝试从源代码访问图像 url 会产生:
<Error>
<Code>AccessDenied</Code>
<Message>Access Denied</Message>
<RequestId><random letters here></RequestId>
<HostId>
<random letters here>
</HostId>
</Error>
但是,如果我在标记媒体文件后转到我的存储桶设置并选择actions
并单击make public
,一切都会开始工作。这意味着对于上传的每张图片,我必须一遍又一遍地标记和重复。
我该如何解决这个问题?