Django实现文件上传下载
2016-01-20 19:19
821 查看
一 django实现文件下载
(1)后台接口
如果从服务器直接将文件路径传给浏览器,普通文件可以直接下载,而图片,html,css和pdf格式等文件会直接显示,所以解决办法就是在头文件中让文件流写入硬盘.
①最简单的文件下载功能的实现,直接将文件流放入HttpResponse对象即可
②更合理的文件下载
Django的
③再次优化
上述的代码,已经完成了将服务器上的文件,通过文件流传输到浏览器,但文件流通常会以乱码形式显示到浏览器中,而非下载到硬盘上,因此,还要在做点优化,让文件流写入硬盘。优化很简单,给StreamingHttpResponse对象的
(2)前台展示
①使用a标签直接访问到上面的视图函数配置好的url即可
②使用button,或者其他标签
使用js触发点击事件,代码如下:
二 文件上传
(1)前台表单,使用表单的方式进行文件的上传
(2)后台接收,这是接收图片的代码,其他文件类似
(1)后台接口
如果从服务器直接将文件路径传给浏览器,普通文件可以直接下载,而图片,html,css和pdf格式等文件会直接显示,所以解决办法就是在头文件中让文件流写入硬盘.
①最简单的文件下载功能的实现,直接将文件流放入HttpResponse对象即可
def file_download(request): # do something... with open('file_name.txt') as f: c = f.read() return HttpResponse(c)这种方式简单粗暴,适合小文件的下载,但如果这个文件非常大,这种方式会占用大量的内存,甚至导致服务器崩溃
②更合理的文件下载
Django的
HttpResponse对象运行将迭代器作为传入参数,将上面代码中的传入参数
c换成一个迭代器,便可以将上述下载功能优化为对大小文件均适合;而Django更进一步,推荐使用
StreamingHttpResponse对象取代
HttpResponse对象,
StreamingHttpResponse对象用于将文件流发送给浏览器,与HttpResponse对象非常相似,对于文件下载功能,使用
StreamingHttpResponse对象更合理。因此,更加合理的文件下载功能,应该先写一个迭代器,用于处理文件,然后将这个迭代器作为参数传递给
StreaminghttpResponse对象,如:
from django.http import StreamingHttpResponse def big_file_download(request): # do something... def file_iterator(file_name, chunk_size=512): with open(file_name) as f: while True: c = f.read(chunk_size) if c: yield c else: break the_file_name = "file_name.txt" response = StreamingHttpResponse(file_iterator(the_file_name)) return response
③再次优化
上述的代码,已经完成了将服务器上的文件,通过文件流传输到浏览器,但文件流通常会以乱码形式显示到浏览器中,而非下载到硬盘上,因此,还要在做点优化,让文件流写入硬盘。优化很简单,给StreamingHttpResponse对象的
Content-Type和
Content-Disposition字段赋下面的值即可
from django.http import StreamingHttpResponse def big_file_download(request): # do something... def file_iterator(file_name, chunk_size=512): with open(file_name) as f: while True: c = f.read(chunk_size) if c: yield c else: break the_file_name = "big_file.pdf" response = StreamingHttpResponse(file_iterator(the_file_name)) response['Content-Type'] = 'application/octet-stream' response['Content-Disposition'] = 'attachment;filename="{0}"'.format(the_file_name) return response
(2)前台展示
①使用a标签直接访问到上面的视图函数配置好的url即可
②使用button,或者其他标签
使用js触发点击事件,代码如下:
$("body").on("click",".buttonimgdown",function(){ alert($(".hiddenshiyan").val()); location.href="/downloadFile/?url="+$(".hiddenshiyan").val(); });
二 文件上传
(1)前台表单,使用表单的方式进行文件的上传
<form enctype="multipart/form-data" action="./upload" method="post"> <p>File: <input type="file" name="file"></p> <p><input type="submit" value="Upload"></p> </form>
(2)后台接收,这是接收图片的代码,其他文件类似
<span style="font-size:14px;color:#000000;">def addOnepicture(req): rollpicturePath=os.path.join(basePath,rollpictureName) reqfile = req.FILES['picfile'] img = Image.open(reqfile) img.thumbnail((500,500),Image.ANTIALIAS)#对图片进行等比缩放 img.save(rollpicturePath,"png")#保存图片 T_Picture.objects.create(<u>...</u>) </span>
相关文章推荐
- mongo笔记
- mongo db ubuntu 12.04安装
- ContentNegotiatingViewResolver
- Go语言daemon启动本身.实现
- django学习随笔(1)
- go的学习记录(一)
- django添加静态文件
- Golang适合高并发场景的原因分析
- google PLDA + 实现原理及源码分析
- Mongoose的模糊查询
- Django学习笔记 自定义标签
- /etc/sudoers配置文件
- poj 1003 Hangover
- django 错误整理
- 解决集成第三方库(这里是AdsMogo芒果聚合)时编译找不到某个语法的问题
- golang中的race检测
- Django+xadmin 显示问题,无法添加inline
- Ubuntu下安装Django
- Golang-and-package-version-managment
- Golang开发中常见错误