4

因为 Heroku 在 30 秒后超时,所以我必须将用户提交的文件直接上传到 S3。将它们上传到 S3 后,我在数据库中插入一个条目来记录我收到了这个文件。这是我的模型:

class UserUploadedFile(models.Model):
    id = models.AutoField(primary_key=True)
    uid = models.ForeignKey('auth.user', editable=False, db_column='uid')
    filepath = models.FileField(storage=S3BotoStorage(bucket='whatever'), upload_to='/')

但是因为 Boto 是自动调用的,所以当我像这样调用 save() 时,会调用 Boto 来处理文件:

file = UserUploadedFile(uid=request.user, filepath=key)
file.save() 

(我确实需要由 Boto 处理文件路径,以便稍后获取其 URL、文件大小等,因此我无法将文件路径转换为字符串。)

无论如何,我尝试像这样覆盖 save() 来绕过 Boto:

def save(self, *args, **kwargs):
    filepath = self.filepath
    if self.filepath:
        self.filepath = ''
    super(UserUploadedFile, self).save(*args, **kwargs)
    self.raw('UPDATE mysite_useruploadedfile SET filepath=%s WHERE id=%d', [filepath, self.pk])

但我得到这个错误:

'UserUploadedFile' object has no attribute 'raw'

我不确定如何在这种情况下调用 raw() ,显然......

...但我的主要问题是,当我写入此表时,这是否是绕过存储引擎的正确方法,或者是否有更清洁的方法

谢谢!

4

1 回答 1

0

您可以使用 django-storages http://django-storages.readthedocs.org/en/latest/index.html之类的应用程序使用自定义后端覆盖存储后端,该应用程序在上传后甚至支持 amazon s3,您可以获得文件很容易

于 2012-09-24T19:36:58.973 回答