django --文件下载的几种方式

方式一:HttpResponse

这种方式简单粗暴,适合小文件的下载,但如果这个文件非常大,这种方式会占用大量的内存,甚至导致服务器崩溃。

其原理是,HttpResponse会先读取文件到内存,然后再输出。

def file_download(request):

  with open('file_name.txt') as f:
    c = f.read()
    
  return HttpResponse(c)

方式二: StreamingHttpResponse + 迭代器 yield

支持各种文件下载,通过文件流传输到浏览器,直接下载到硬盘。

​ Django,推荐使用 StreamingHttpResponse对象取代HttpResponse对象,StreamingHttpResponse对象用于将文件流发送给浏览器,与HttpResponse对象非常相似,对于文件下载功能,使用StreamingHttpResponse对象更合理。

from django.http StreamingHttpResonse

def file_download(request):
    file_path = request.GET.get('file_path')
    file_name = request.GET.get('file_name')
    
    response = StreamingHttpResponse(file_iter(file_path+file_name))	# 获取文件流
    response['Content-Type'] = 'application/octet-stream'	# 支持所有流文件(二进制)
    response['Content-Dispositon'] = 'attachment;filename="{}"'.format(file_name)	# 下载文件名
    
# 文件流读取 -- 迭代器
def file_iter(file, chunk_size=1024):
    # chunk_size=1024 表示一次最大1024k
    with open(file, 'rb') as f:
        while True:
            c = f.read(chunk_size)
            if c:
                yield c
            else:
                break

前端

<button type='button' onclick="download('{{ file_path }}', '{{ file_name }}')"> 点击下载 </button>

<script>
    function download(path, name){
        location.href = "/file_download/?file_path=" + path + "&file_name=" + name	// url路径
    }
</script>

方式三:StreamingHttpResponse + FileWrapper

不用自己手写迭代器

from django.http StreamingHttpResonse
from wsgiref.util import FileWrapper

def file_download(request):
    file_path = request.GET.get('file_path')
    file_name = request.GET.get('file_name')
    wrapper = FileWrapper(open(file_path, 'rb'))		# 将文件对象转换为可迭代对象
    
    response = StreamingHttpResponse(wrapper)	# 获取文件流
    response['Content-Type'] = 'application/octet-stream'	# 支持所有文件
    response['Content-Dispositon'] = 'attachment;filename="{}"'.format(file_name)	# 下载文件名

方式四: FileResponse

FileResponse是StreamingHttpResonse的一个子类,属于文件返回方式。

from django.http import HttpResponse, FileResponse
 
 
def file_response_download1(request, file_path, file_name):
 
    response = FileResponse(open(file_path+file_name, 'rb'))
    response['content_type'] = "application/octet-stream"
    response['Content-Disposition'] = 'attachment; filename=' + file_name
    return response

方式五: 配置media文件或static文件

项目中指定media路径,直接访问即可;
nginx配置alias路径;也可直接访问;

  • 1
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
django-gridfs-storage是一个用于在Django项目中使用GridFS存储后端的库。GridFS是MongoDB的一种存储引擎,它可以用于存储大型文件,解决了传统的文件存储方式的一些限制。 使用django-gridfs-storage,我们可以轻松地在Django项目中将文件存储到MongoDB的GridFS中,同时利用Django提供的模型和视图来管理和访问这些文件。 使用django-gridfs-storage主要包含以下几个步骤: 1. 安装和配置:使用pip命令安装django-gridfs-storage库,并在Django的设置文件中添加相关配置,包括MongoDB连接信息和GridFS的collection名称等。 2. 模型定义:定义一个继承自django.db.models.FileField的字段,将其作为模型的一个属性。这个字段将用于存储文件在GridFS中的存储位置。 3. 视图和表单:在Django的视图中,使用GridFSStorage提供的一些方法来操作文件,比如保存文件、获取文件、删除文件等。同时,可以根据需要创建合适的表单来处理文件上传。 4. 文件访问:使用Django模板系统来展示文件或者生成文件下载链接,可以通过模型实例的属性来获取文件的URL,然后在模板中使用该URL来创建适当的HTML链接标签。 使用django-gridfs-storage可以有效地管理大型文件的存储和访问,而无需担心文件大小限制等问题。同时,结合Django强大的开发框架,我们可以更加灵活和方便地处理文件的上传、下载和展示等操作。这使得django-gridfs-storage成为在Django项目中使用MongoDB存储文件的理想选择。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

像风一样的男人@

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值