gpt4 book ai didi

python - 允许用户下载在 AWS 上生成的 zip 文件

转载 作者:行者123 更新时间:2023-12-01 01:46:56 25 4
gpt4 key购买 nike

这是我生成 ZIP 并从服务器下载它的方法,它在本地开发中运行良好。

import zipfile
doc = get_object_or_404(Document,id=id_obj)
filepath = doc.file.path
filename = os.path.basename(doc.file.name)
directory = os.path.dirname(filepath)

xzip = zipfile.ZipFile(os.path.join(directory,"%s.zip" % filename), "w")
xzip.write(filepath,filename)
xzip.close()

zip_file = open(xzip.filename, 'rb')
response = HttpResponse(zip_file, content_type='application/zip')
response['Content-Disposition'] = 'attachment; filename="%s.zip"' %
os.path.splitext(filename)[0]
return response

我的所有静态和媒体文件都已上传到生产环境中的 AWS。所以我稍微改变一下

 # filepath becomes
filepath = settings.MEDIA_ROOT + "/" + doc.file.name

但是当我尝试下载它时,它给我[Errno 2]没有这样的文件或目录以及链接:

https://bucket_name.s3.amazonaws.com/media/public/files/file.pdf.zip

settings.MEDIA_ROOT 是:

AWS_ACCESS_KEY_ID = config('AWS_ACCESS_KEY_ID')
AWS_SECRET_ACCESS_KEY = config('AWS_SECRET_ACCESS_KEY')

AWS_STORAGE_BUCKET_NAME = 'bucket_name'
AWS_S3_CUSTOM_DOMAIN = '%s.s3.amazonaws.com' % AWS_STORAGE_BUCKET_NAME

AWS_PUBLIC_MEDIA_LOCATION = 'media/public'
<b>MEDIA_ROOT = "https://%s/%s/" % (AWS_S3_CUSTOM_DOMAIN, AWS_PUBLIC_MEDIA_LOCATION)</b>

doc.file.path 给我错误:'此后端不支持绝对路径',这就是我更改为 MEDIA_ROOT + doc 的原因。文件名

如何从 AWS 下载生成的 zip 文件?

最佳答案

该文件存在于 S3 上,而不是本地文件系统上。当您调用这些 os.path.* 函数时,代码会尝试在本地文件系统上查找该文件。它给你这个错误是因为你给它的 S3 URL 作为路径无法映射到本地文件系统上的任何内容。

为什么不允许 S3 通过简单地返回带有 S3 文件 URL 的重定向响应来直接向最终用户的浏览器提供文件,而不是尝试读取文件并返回响应中的内容?

关于python - 允许用户下载在 AWS 上生成的 zip 文件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51223791/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com