技术博客Django中文件下载的实现

Posted 1606-huluwa

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了技术博客Django中文件下载的实现相关的知识,希望对你有一定的参考价值。

开发组在开发过程中,都不可避免地遇到了一些困难或问题,但都最终想出办法克服了。我们认为这样的经验是有必要记录下来的,因此就有了【技术博客】。


Django中文件下载的实现

1、背景

在VisualPytorch项目中,当时需要提供一个文件下载的功能。最初想到的方案主要有一下三种

  • 直接把网页前端的字符串写入文件中,在客户端完成。

这个方案经过查找资料发现不同浏览器的同源策略以及安全策略不尽相同,难以实现,放弃。

  • 在服务器上再开一个ftp服务器系统地提供文件服务。

这是最开始的思路,后来根据实际需求认为目前服务器性能本身就有限,加上目前项目对文件需求比较简单,不需要复杂的文件服务。

  • 直接在服务器固定目录下生成文件,打包后通过http流的形式传输

最终采用的实现方法,比较简单好实现。

2、Django后端中的文件打包与下载

关于文件打包,在实现时使用了zipfile这个python包

zipf = zipfile.ZipFile("project_VisualPytorch.zip", 'w',zipfile.ZIP_DEFLATED)

关于zipfile的使用详情请见https://docs.python.org/3/library/zipfile.html

服务器后台是通过构造Http的response对象向前端发送数据的,对于较大的文件传输来说,这里推荐使用Django框架中的StreamingHttpResponse或FileResponse构造响应对象。

StreamingHttpResponse采用流式传输文件,参数是一个迭代器,对文件进行分片传输,实现如下

response = StreamingHttpResponse(file_iterator("project_VisualPytorch.zip"))
response['Content-Type'] = 'application/zip'
response['Content-Disposition'] = 'attachment;filename="project_VisualPytorch.zip"'
return response

迭代器构造如下

def file_iterator(file_name, chunk_size=512):
    with open(file_name, 'rb') as f:
        while True:
            c = f.read(chunk_size)
            if c:
                yield c
            else:
                break

这里设置分片大小为512。

FileResponse是StreamingHttpResponse的子类,使用了缓存等技术,某些情况下优于其父类。

以上是关于技术博客Django中文件下载的实现的主要内容,如果未能解决你的问题,请参考以下文章

[技术博客]使用pylint实现django项目的代码风格检查

如何在 Django Summernote 中显示编程片段的代码块?

django中使用FastDFS分布式文件系统接口代码实现文件上传下载更新删除

我的Android进阶之旅NDK开发之在C++代码中使用Android Log打印日志,打印出C++的函数耗时以及代码片段耗时详情

Django搭建博客网站

Django搭建博客网站