django之下载文件

Posted loveprogramme

tags:

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

一、文件下载介绍

 这是一个展示图片的网页;

技术图片

 

 这是直接加载图片资源的网页,看网页的后缀名就知道了;

技术图片

 

 也能找到直接点击就可以下载的页面,就像PDF文件一样,有的是可以直接下载,而有的是被浏览器加载,然后再右键下载,不同的行为与不同的参数设定有关,下面就来具体展示如何下载一个文件。

掌握:(在设置中设置媒体文件的目录和URL,然后在与templates统计的目录下设置一个media文件夹,用于存放媒体文件)

# 添加流媒体文件
MEDIA_URL = /media/

MEDIA_ROOT = os.path.join(BASE_DIR, media)

技术图片

 

 设置好后,启动项目,就可以通过访问"http://XXX.XXX.XXX.XXX/media/filename.ext/"在请求媒体文件了。

二、文件下载操作

HTML

技术图片

 

 route

技术图片

 

 view function

from django.shortcuts import render
from .models import Doc
from django.http import FileResponse, Http404
from dj32_test.settings import dev
import requests
import logging
from django.utils.encoding import escape_uri_path

logger = logging.getLogger("django")
# Create your views here.
def document(request):
    docs = Doc.objects.only("title", "desc", "image_url", "file_url", "id").filter(is_delete=False)
    return render(request, doc/docDownload.html, {"docs": docs})


def document_download(request, doc_id):
    doc_obj = Doc.objects.only("file_url", "title").filter(is_delete=False, id=doc_id).first()
    # 表明文档是否存在
    if doc_obj:
        # 获取文件路径
        file_url = doc_obj.file_url
        # 拼接成完整的url
        # BASE_URL为自定义设置,表示网站的域名
        file_url = dev.BASE_SITE + file_url
        try:
            # 使用requests获取文件请求对象
            # FileResponse会自动从response获取文件内容
            response = FileResponse(requests.get(file_url, stream=True))
        except requests.exceptions.ConnectionError as e:
            logging.error(e)
            response.status_code = Connection Refused
        # 取得文件的后缀名
        file_ext = file_url.split(".")[-1]
        if not file_ext:
            raise Http404("文件名异常")
        else:
            file_ext = file_ext.lower()
        # 检查文件后缀名,赋予对应的Content-Type
        if file_ext == "pdf":
            response["Content-Type"] = "application/pdf"
        elif file_ext == "doc":
            response["Content-Type"] = "application/msword"
        elif file_ext == "ppt" :
            response["Content-Type"] = "application/vnd.ms-powerpoint"
        else:
            raise Http404("文件格式错误")
        # 过滤文件名,去掉不安全的字符
        file_name = escape_uri_path(doc_obj.title + "." + file_ext)
        # 给用户提供一个默认的文件名,如果没有设置,则默认为“下载.ext”
        # 如果是attachment,就直接下载
        # 如果是inline,就在浏览器中打开
        # filename表示下载时的文件名,如果没有则是“下载.ext”
        response["Content-Disposition"] = "inline; filename={}".format(file_name)
        return response
    else:
        raise Http404("Doc Not Found")

规范:

  1、根据文件id到数据库中找到文件的路径,并拼接域名,得到文件的完整url;(有的文件是存放在本地的,有的是使用对象存储服务存储的)

  2、使用requests库请求文件资源,获取response对象,传递给FileResponse,生成文件响应对象;

  3、获取文件扩展名并检查是否存在,设置相应的Content-Type;

  4、准备下载的文件名,去掉不安全的字符;

  5、设置文件资源展示方式:直接下载、浏览器展示

技术图片

 

以上是关于django之下载文件的主要内容,如果未能解决你的问题,请参考以下文章

Jmeter之下载文件

Java Web之下载文件

NetCore.NetCore之下载文件

NetCore.NetCore之下载文件

NetCore.NetCore之下载文件

HttpServletResponse实战之下载文件与动态验证码Javaweb