Python+Django实现文件的下载

在我们用浏览器浏览网页时,浏览器会帮我们自动解析它支持的文件类型。但是有时我们需要让用户去保存这些文件,而不是让浏览器直接解析。所以这时就要对服务器发给浏览器的response做一些特别的设置,让浏览器不去解析这些文件。在response中需要去设置Content-Disposition和Content-Type的值。这样浏览器就不会去解析这些数据,而弹出下载框让用户下载。实例如下:

example1:使用HttpResponse

from django.shortcuts import HttpResponse
def file_down(request):
    file=open('/home/amarsoft/下载/example.tar.gz','rb')
    response =HttpResponse(file)
    response['Content-Type']='application/octet-stream'
    response['Content-Disposition']='attachment;filename="example.tar.gz"'
    return response
example2:使用StreamingHttpResponse

from django.http import StreamingHttpResponse
def file_down(request):
    file=open('/home/amarsoft/下载/example.tar.gz','rb')
    response =StreamingHttpResponse(file)
    response['Content-Type']='application/octet-stream'
    response['Content-Disposition']='attachment;filename="example.tar.gz"'
    return response
example3:使用FileResponse

from django.http import FileResponse
def file_down(request):
    file=open('/home/amarsoft/下载/example.tar.gz','rb')
    response =FileResponse(file)
    response['Content-Type']='application/octet-stream'
    response['Content-Disposition']='attachment;filename="example.tar.gz"'
    return response
虽然使用这三种方式都能实现,但是推荐用FileResponse,在FileResponse中使用了缓存,更加节省资源。虽说是三种方式,但是原理相同,说白了就是一种方式。为了更好的实现文件下载,FileResponse对StreamingHttpResponse做了进一步的封装,即StreamingHttpResponse是FileResponse的父类。而HttpResponse,StreamingHttpResponse,FileResponse三者都继承了基类HttpResponseBase。HttpResponseBase类是一个字典类,其封装了一个_headers属性,该属性是一个字典类型,里面封装了response的头信息。因为该HttpResponseBase类被封装成了一个字典类,所以可以直接使用response['Content-Type']这种形式访问,也可以使用response._headers['Content-Type']访问。值得注意的是:

1.HttpResponseBase只有来设置response的头信息,并不能返回给客户端发生数据。

2.response.keys()这中形式不能访问到字典的方法,必须使用response._headers.keys()才能访问到字典的方法。



猜你喜欢

转载自blog.csdn.net/li627528647/article/details/77544136
今日推荐