2

所有文件,包括那些未正确显示的文件,都存在于我在亚马逊的存储桶中。我发现仅有的两个不显示的图像是 icon_clock.gif 和 icon_calendar.gif。其他一切正常。

当我检查损坏图像的链接位置时,我得到了这个:

 https://my_bucket_name.s3.amazonaws.com/admin?Signature=MY_SIGNATURE&AWSAccessKeyId=MY_KEYimg/icon_clock.gif

如您所见,查询参数并未添加到末尾,而是添加到链接的中间。

以下是相关设置:

import os.path

ROOT_DIR = os.path.abspath(os.path.join(os.path.dirname(__file__), '..'))
PROJECT_NAME = os.path.basename(ROOT_DIR)

def ABS_PATH(*args):
    return os.path.join(ROOT_DIR, *args)

STATIC_ROOT = ABS_PATH('static')

AWS_ACCESS_KEY_ID = 'MY_KEY'
AWS_SECRET_ACCESS_KEY = 'MY_SECRET_ACCESS_KEY'

AWS_STORAGE_BUCKET_NAME = 'my_bucket_name'
STATICFILES_STORAGE = 'storages.backends.s3boto.S3BotoStorage'
S3_URL = 'http://%s.s3.amazonaws.com/' % AWS_STORAGE_BUCKET_NAME
STATIC_URL = S3_URL
4

1 回答 1

5

这似乎在 django-storages 的当前开发版本中已修复。有关详细信息,请参阅第 121期。

快速解决方法步骤:

  1. django-storages在您的 requirements.txt 中替换为-e hg+https://bitbucket.org/david/django-storages@e27c8b61ab57e5afaf21cccfee005c980d89480f#egg=django_storages-dev
  2. 在您的设置中,添加AWS_QUERYSTRING_AUTH = False. 此设置的结果是 AWS auth 内容未包含在每个 URL 中。仅当您的 S3 存储桶中的所有文件都是公开的时才执行此操作。
于 2013-09-09T12:30:24.810 回答