一、文件下载介绍
这是一个展示图片的网页;
这是直接加载图片资源的网页,看网页的后缀名就知道了;
也能找到直接点击就可以下载的页面,就像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、设置文件资源展示方式:直接下载、浏览器展示