根据我的阅读,静态文件应由服务器直接提供,而不是使用Python和Django。但我需要限制文件访问上传它们的用户。不幸的是,文档中没有关于提供用户在生产环境中上传的静态文件的部分。
如果我是对的,Facebook会使用难以猜测的长网址。这听起来像是一种合理的方法。如何在Django中自动生成长ID并将其用于上传的媒体文件?
答案 0 :(得分:5)
您可以使用slugify
和datetime
。
from django.template.defaultfilters import slugify
import datetime
class MyModel(models.Model):
title = models.CharField(max_length=150, db_index=True)
image = models.Charfield(max_length=150, unique=True)
....
....
def save(self):
super(MyModel, self).save()
date = datetime.date.today()
self.image = '%i/%i/%i/%s' % (
date.year, date.month, date.day, slugify(self.title)
)
super(MyModel, self).save()
或只是
使用time
from time import time
def get_upload_file_name(instance, filename):
return "uploaded_files/%s_%s" %(str(time()).replace('.','_'), filename)
class MyModel(models.Model):
description = models.TextField()
image = models.ImageField(upload_to=get_upload_file_name)
def __unicode__(self):
return "%s --> %s" % (self.user, self.description)
或强>
使用此模块 - django-unique-random
希望它有所帮助!
答案 1 :(得分:1)
如果您想以正确的方式执行此操作,则应在支持它们的Web服务器中使用X-SendFile / X-Accel-Redirect标头(Apache,NGinx,或许更多)。您可能需要在Web服务器上启用模块(例如Apache中的mod_xsendfile)。
X-SendFile的作用是它指示前端Web服务器用X-SendFile头中提到的文件替换响应的主体。这样,您可以让Django应用程序检查文件的访问权限,同时将文件下载服务卸载到前端服务器。