1、Django
实现文件下载css
(1)、后台接口html
若是从服务器直接将文件路径传给浏览器,普通文件能够直接下载,而图片,html,css和pdf格式等文件会直接显示,因此解决办法就是在头文件中让文件流写入硬盘.python
①、最简单的文件下载功能的实现,直接将文件流放入HttpResponse
对象便可浏览器
def file_download(request): # do something... with open('file_name.txt') as f: c = f.read() return HttpResponse(c)
这种方式简单粗暴,适合小文件的下载,但若是这个文件很是大,这种方式会占用大量的内存,甚至致使服务器崩溃服务器
②、更合理的文件下载app
Django
的HttpResponse
对象运行将迭代器做为传入参数,将上面代码中的传入参数c换成一个迭代器,即可以将上述下载功能优化为对大小文件均适合;而Django
更进一步,推荐使用 StreamingHttpResponse
对象取代HttpResponse
对象,StreamingHttpResponse
对象用于将文件流发送给浏览器,与HttpResponse
对象很是类似,对于文件下载功能,使用StreamingHttpResponse
对象更合理。所以,更加合理的文件下载功能,应该先写一个迭代器,用于处理文件,而后将这个迭代器做为参数传递给StreamingHttpResponse
对象,如:函数
from `Django`.http import Streaming`HttpResponse` 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 = Streaming`HttpResponse`(file_iterator(the_file_name)) return response
③、再次优化post
上述的代码,已经完成了将服务器上的文件,经过文件流传输到浏览器,但文件流一般会以乱码形式显示到浏览器中,而非下载到硬盘上,所以,还要在作点优化,让文件流写入硬盘。优化很简单,给StreamingHttpResponse
对象的Content-Type和Content-Disposition字段赋下面的值便可优化
from `Django`.http import Streaming`HttpResponse` 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 = Streaming`HttpResponse`(file_iterator(the_file_name)) response['Content-Type'] = 'application/octet-stream' response['Content-Disposition'] = 'attachment;filename="{0}"'.format(the_file_name) return response
(2)、前台展现url
①、使用a标签直接访问到上面的视图函数配置好的url便可
②、使用button,或者其余标签
使用js触发点击事件,代码以下:
$("body").on("click",".buttonimgdown",function(){ alert($(".hiddenshiyan").val()); location.href="/downloadFile/?url=" rel="external nofollow" +$(".hiddenshiyan").val(); });
2、 文件上传
(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)、后台接收,这是接收图片的代码,其余文件相似
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>)