Models 中新建了一个模型,并且设置 path 为 FileFiled 格式的
这样就可设置为文件属性了,在django-web上上传文件时,path为文件的路径,相信这点官网已经写的非常详细了
下面记录下如何指定文件的存储路径、文件访问路径、文件下载
存储文件
存储文件需要指定文件的存储路径
在 settings.py 文件中增加字段:
MEDIA_ROOT
例如:
当在自己的电脑上模拟运行时可以指定为
MEDIA_ROOT = os.path.join(BASE_DIR, 'Files')
这样会在项目根目录下创建一个名称为"Files"文件夹
所有上传的文件都会存储到这个文件夹下面
当然,线上肯定将文件放置公司服务器上,路径做相应的修改。
访问路径
访问路径就是在web或者APP等上面访问该文件的路径
在 settings.py 文件中增加字段 MEDIA_URL
例如:
MEDIA_URL = '/Files/'
并且你的服务地址为:127.0.0.1:8000
则访问路径为 127.0.0.1:8000/Files/文件名称
下载文件
在访问路径设置好后,如果这个时候去访问文件,会发现根本访问不到。
提示“该文件不存在”等提示
为什么呢?
因为没有将访问路径映射到本地文件路径
例如:
访问: 127.0.0.1:8000/Files/文件名称
需要将路径映射到: /Users/***/Desktop/ProjectName/Files/文件名称
如何映射
在urls.py 文件中增加静态文件的映射
# 静态文件的访问
from django.conf.urls.static import static
import settings
urlpatterns = [
] + static(settings.MEDIA_URL, document_root=settings.MEDIA_ROOT)
如此便可以很好的访问·下载文件了
补充:文件重命名
当我们上传一个文件到服务器时,希望重新更改一下该文件的名称和路径
在models 里面模型创建的时候指定
class TestModel(models.Models):
path = models.FileField(verbose_name='路径',
upload_to=upload_to,
help_text='只能是 zip 文件')
注意 upload_to 则为自定义文件名称·路径的方法
def upload_to(instance, fielname):
# 后缀
sub = fielname.split('.')[-1]
t = time.strftime('%Y%m%d%H%M%S', time.localtime())
return 'test1/namespace/%s.%s' % (t,sub,)
如上实现:
会将文件名称更改为时间戳,并且在 MEDIA_ROOT 下新建两层文件夹 test1/namespace ,将文件放置在 namespace 下。
如此是文件操作的设置