Django4 中文入门教程 Django4.0 管理文件-文件存储

2024-02-25 开发教程 Django4 中文入门教程 匿名 6

在后台,Django将如何以及在哪里存储文件的决策委托给文件存储系统。这个对象实际上理解文件系统、打开和读取文件等。

Django 的默认文件存储通过 ​DEFAULT_FILE_STORAGE ​配置;如果你不显式地提供存储系统,这里会使用默认配置。

存储对象

虽然大部分时间你可以使用 File 对象(将该文件委托给合适的存储),但你可以直接使用文件存储系统。你可以创建一些自定义文件存储类的示例,或使用通常更有用的全局默认存储系统:

>>> from django.core.files.base import ContentFile
>>> from django.core.files.storage import default_storage
>>> path = default_storage.save('path/to/file', ContentFile(b'new content'))
>>> path
'path/to/file'
>>> default_storage.size(path)
11
>>> default_storage.open(path).read()
b'new content'
>>> default_storage.delete(path)
>>> default_storage.exists(path)
False

内置文件存储类

Django 附带一个 ​django.core.files.storage.FileSystemStorage​ 类,这个类实现基础的本地文件系统文件存储。
例如,下面的代码将存储上传文件到 ​/media/photos​ 而会忽略你在 ​MEDIA_ROOT ​的设置:

from django.core.files.storage import FileSystemStorage
from django.db import models
fs = FileSystemStorage(location='/media/photos')
class Car(models.Model):
...
photo = models.ImageField(storage=fs)

自定义存储系统( Custom storage systems )的工作方式也一样:将它们作为 ​storage ​参数传递给 ​FileField ​。

使用callable

你可以使用callable作为 ​FileField ​或 ​ImageField ​的 ​storage ​参数。它允许你在运行时修改存储参数,不同环境选择不同存储,例如。
当模型类被加载时,callable将进行判断,并返回 ​Storage ​实例。

例如:

from django.conf import settings
from django.db import models
from .storages import MyLocalStorage, MyRemoteStorage
def select_storage():
return MyLocalStorage() if settings.DEBUG else MyRemoteStorage()
class MyModel(models.Model):
my_file = models.FileField(storage=select_storage)