3. 前后端实现压缩包文件下载

1. 说明

在数据管理当中,批量处理某些文件,并以压缩包的形式在前端进行下载是很常见的功能,本文将简要讲述如何实现此功能,主要包括后端文件的整合与发送,前端文件的接收与下载。

2. 具体步骤

2.1 后端文件处理与发送

后端接收到文件下载的指令后,需要根据具体业务处理相关文件,比如从数据库中把相关数据读取出来并保存到文件中,后端的上传只需要文件的具体地址,这里相关文件的内容操作不再说明,只记录如何将已经处理好的文件进行上传的方法,具体操作如下代码:

python 复制代码
from flask import Flask, request, jsonify
from flask_cors import CORS
from flask import send_file
import os
import zipfile

app = Flask(__name__)

CORS(app)

@app.route('/testDownload/', methods=['GET','POST'])
def testDownload():
	# 这里省略具体文件内容的操作,直接拿到需要下载的文件路径
	download_file_path_list = ["./测试文件一.txt","测试文件二.txt"]
	zip_file_name = "test_files.zip"
	with zipfile.ZipFile(zip_file_name, 'w') as zipf:
		# 遍历路径列表,把指定文件写入到压缩包中
		for filePath in download_file_path_list:
			zipf.write(filePath, os.path.basename(filePath))
	# 发送压缩文件
	return send_file(zip_file_name, as_attachment=True)

if __name__ == '__main__':
	app.run(host = '0.0.0.0', debug = True)
2.2 前端文件接收

此处只做简单测试,前端页面的整体代码可根据项目需要自行设计,这里只给出响应方法实现,比如为一个按钮添加点击事件的处理方法,相关代码如下;

javascript 复制代码
testDownLoad(){
	let download_url = '/api/testDownload';
	axios.get(download_url,{
		responseType: 'blob'
	}).then(response => {
			let blob = new Blob([response.data], {type: 'text/case;chalet=ute-8;'});
			let url = URL.createObjectURL(blob);
			let link = document.createElement('a');
			link.setAttribute('href', url);
			link.setAttribute('download', 'test'+'.zip');
			document.body.appendChild(link);
			link.click();
			document.body.removeChild(link);
		});
}

结束,没啥问题应该是可以实现功能的。

相关推荐
前端一课4 分钟前
【前端每天一题】🔥第7题 事件冒泡与事件捕获 - 前端高频面试题
前端·面试
前端一课5 分钟前
【前端每天一题】 第 5 题:Promise.then 执行顺序深入题(微任务队列机制)
前端·面试
前端一课9 分钟前
【前端每天一题】🔥 事件循环第 6 题:setTimeout(fn, 0) 执行时机详解
前端·面试
前端一课10 分钟前
【前端每天一题】🔥 第3题 事件循环 20 道经典面试题(附详细答案)
前端·面试
前端一课12 分钟前
【前端每天一题】第 2 题:var、let、const 的区别?(绝对高频)
前端·面试
前端一课16 分钟前
【前端每天一题】🔥第四题 原型与原型链 - 前端面试必考题
前端·面试
初见00119 分钟前
告别无限循环:深入理解并征服 React Hooks 的依赖数组
前端
一颗不甘坠落的流星21 分钟前
【HTML】iframe 标签 allow 权限汇总(例如添加复制粘贴权限)
前端·javascript·html
用户3458482850522 分钟前
Java中还有哪些方式可以保证多线程环境下的原子性?
后端
亦草23 分钟前
浅谈现代前端体系:组件化、模块化、类型系统与工程化
前端