【发布时间】:2016-11-06 16:06:23
【问题描述】:
如何将 Django 自定义存储后端与 Google Cloud Storage 结合使用?
尝试使用这个:ckopanos's django-google-cloud-storage
根据文档,我已将以下内容添加到我的“settings.py”中:
GOOGLE_CLOUD_STORAGE_BUCKET = [my bucket name] # the name of the bucket you have created from the google cloud storage console
GOOGLE_CLOUD_STORAGE_URL = [my bucket URL] #whatever the url for accessing your cloud storgage bucket
GOOGLE_CLOUD_STORAGE_DEFAULT_CACHE_CONTROL = [cache control] # default cache control headers for your files
DEFAULT_FILE_STORAGE = 'google.storage.googleCloud.GoogleCloudStorage'
我将“google”文件夹/包添加到我的项目文件中,因此“settings.py”应该可以访问它
我现在如何在我的视图中使用此自定义存储系统?
我可以通过执行以下操作手动使用 gcs(此示例在 gcs 上存储 xlsx):
import cloudstorage as gcs
from google.appengine.api import app_identity
import xlsxwriter
import StringIO
bucket_name = os.environ.get('BUCKET_NAME',
app_identity.get_default_gcs_bucket_name())
bucket = '/' + bucket_name
filename = bucket + '/'+ userid + '/' + [some code] + '.xlsx'
gcs_file = gcs.open(filename,
'w',
content_type='application/vnd.openxmlformats-officedocument.spreadsheetml.sheet',
options={'x-goog-meta-user': userid})
output = StringIO.StringIO()
workbook = xlsxwriter.Workbook(output, {'in_memory': True})
worksheet = workbook.add_worksheet()
worksheet.write(0, 0, 'Hello World')
# Close the workbook before streaming the data.
workbook.close()
# Rewind the buffer.
output.seek(0)
gcs_file.write(output.read())
gcs_file.close()
如何导入存储系统以在我的视图中使用?你会为 Django 和 GCS 推荐不同的存储系统吗?
【问题讨论】:
-
谁推荐的?目的是什么?
-
对不起,让我换个说法。将 Django 与 Cloud Storage 连接起来的最简单方法是什么,或者最容易实现包(仍在维护)?无需编写我自己的自定义存储系统。 (即,是否有一个我可以使用的“即插即用”包得到维护,并且开发开销很小)。目的是:将 xlsx、xls 和 csv 文件从多个用户上传到 gcs,并允许私人下载这些相同的文件(仅限于上传文件的用户)。
-
寻找一个包显然是题外话,最简单的方法可能过于基于意见。请参阅How to Ask。
-
好吧,我已经把问题更具体了,针对我一直在尝试使用的特定包。
标签: python django google-app-engine google-cloud-storage django-storage