Django中如何进行下载服务器搭建,操作是什么
Admin 2022-07-19 群英技术资讯 339 次浏览
# 创建Download项目 django-admin startproject Download # 创建down_app app python manage.py startapp down_app
Download/Download/settings.py
1.添加注册APP:down_app
2.设置模板文件路径:templates
3、编写视图函数:views.py
Download/down_app/views.py
import os from django.http import HttpResponse from django.http import StreamingHttpResponse def image_down(request): """ 下载图片 """ img_name = request.GET.get("username") + ".png" # 二维码图片名 base_dir = os.path.dirname(os.path.dirname(os.path.abspath(__file__))) # 项目根目录 file_path = os.path.join(base_dir, 'antirisk/CodeGenerate/image/code', img_name) # 二维码的绝对路径 if not os.path.isfile(file_path): # 判断下载文件是否存在 return HttpResponse("Sorry but Not Found the File") def file_iterator(file_path, chunk_size=512): """ 文件生成器,防止文件过大,导致内存溢出 :param file_path: 文件绝对路径 :param chunk_size: 块大小 :return: 生成器 """ with open(file_path, mode='rb') as f: while True: c = f.read(chunk_size) if c: yield c else: break try: # 设置响应头 # StreamingHttpResponse将文件内容进行流式传输,数据量大可以用这个方法 response = StreamingHttpResponse(file_iterator(file_path)) # 以流的形式下载文件,这样可以实现任意格式的文件下载 response['Content-Type'] = 'application/octet-stream' # Content-Disposition就是当用户想把请求所得的内容存为一个文件的时候提供一个默认的文件名 response['Content-Disposition'] = f'attachment;filename="1.png"' # 文件名不可设置为中文 except: return HttpResponse("Sorry but Not Found the File") return response
4、修改路由配置:urls.py
Download/Download/urls.py
from django.contrib import admin from django.urls import path, re_path from down_app import views urlpatterns = [ path('admin/', admin.site.urls), path('', views.index), re_path('download/)', views.image_down, name="download"), ]
5、创建并编写:index.html
Download/templates/index.html
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Title</title> </head> <body> <a href="/download/" rel="external nofollow" >下载图片</a> </body> </html>
运行
# 运行项目 python manage.py runserver
# 访问: http://127.0.0.1:8000/
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
写爬虫是一个发送请求,提取数据,清洗数据,存储数据的过程。在这个过程中,不同的数据源返回的数据格式各不相同,有 JSON 格式,有 XML 文档,不过大部分还是 HTML 文档,HTML 经常会混杂有转移字符,这些字符我们需要把它转义成真正的字符
Python内置函数-vars()函数。vars() 函数返回对象object的属性和属性值的字典对象。
容器数据类型包括数组list,字典dict以及元组tuple等。本篇主要介绍了ChainMap字典序列的使用,需要的朋友们下面随着小编来一起学习学习吧
这篇文章主要给大家介绍了关于Pandas知识点之缺失值处理的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
本篇文章给大家带来了关于Python的相关知识,主要介绍了Python如何用NumPy读取和保存点云数据,文章围绕主题展开详细的内容介绍,具有一定的参考价值,需要的小伙伴可以参考一下。
成为群英会员,开启智能安全云计算之旅
立即注册Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008