首先,启用Django的S3后端存储,可以使用django-storages。详见:https://django-storages.readthedocs.io/en/latest/backends/amazon-S3.html
在settings.py文件中添加以下内容以配置存储后端:
# setting.py
# ...
AWS_ACCESS_KEY_ID = 'your_access_key_id'
AWS_SECRET_ACCESS_KEY = 'your_secret_access_key'
AWS_STORAGE_BUCKET_NAME = 'your_bucket_name'
AWS_S3_REGION_NAME = 'your_region_name'
AWS_S3_ENDPOINT_URL = 'your_s3_endpoint_url'
# Use Amazon S3 for storing uploaded media files.
DEFAULT_FILE_STORAGE = 'storages.backends.s3boto3.S3Boto3Storage'
请确保设置了AWS_ACCESS_KEY_ID和AWS_SECRET_ACCESS_KEY以使用AWS S3 API访问存储桶。 AWS_S3_REGION_NAME是您创建S3存储桶时选择的区域,AWS_STORAGE_BUCKET_NAME是您在S3控制台中创建的bucket name。如果使用的是S3区域外的第三方服务,则可能需要提供AWS_S3_ENDPOINT_URL。
安装django-s3-storage后,在template中使用它来呈现图像:
# your_app/views.py
from django.shortcuts import render
from django.conf import settings
import os
def your_view(request):
context = {}
image_path = os.path.join(settings.MEDIA_ROOT, 'your_image_name.jpg')
context['image_url'] = settings.AWS_S3_ENDPOINT_URL + '/' + settings.AWS_STORAGE_BUCKET_NAME + image_path
return render(request, 'your_template.html', context=context)
在templates中:
这里是我们通过将MEDIA_ROOT与媒体文件名连接来设置image_path变量,然后使用AWS_S3_ENDPOINT_URL和AWS_S3_STORAGE_BUCKET_NAME从settings.py文件提取S3 URL。在template中使用它呈现图像。