python flask解决上传下载的问题
记录瞬间
最近为了解决一些新的需求,简单介入了flask对文件的上传和下载的方法,并分别使用python和curl模拟发送
代码:
#! /usr/bin/env python3
# coding:utf-8
import platform from werkzeug.utils import secure_filename
from flask import Flask, jsonify, request, Response
import os app = Flask(__name__)
UPLOAD_FOLDER = 'upload'
app.config['UPLOAD_FOLDER'] = UPLOAD_FOLDER
app.config['MAX_CONTENT_LENGTH'] = 20 * 1024 * 1024 # 定义最大上传文件大小为:20M ALLOWED_EXTENSIONS = set(['txt', 'png', 'jpg', 'xls', 'JPG', 'PNG', 'zip', 'gif', 'GIF'])
run_path = "./" # 根据不同的操作系统,定义基础运行路径
if platform.system() == "Linux":
run_path = r'/opt/AutoUpload/'
if platform.system() == "Windows":
run_path = r'D:/PythonWorkSpace/'
msg = 'niGEin!' # 用于判断文件后缀
def allowed_file(filename):
return '.' in filename and filename.rsplit('.', 1)[1] in ALLOWED_EXTENSIONS # 上传文件-upload-file
@app.route('/uf', methods=['POST'], strict_slashes=False)
def api_upload():
file_dir = run_path + UPLOAD_FOLDER
if not os.path.exists(file_dir):
os.makedirs(file_dir)
f = request.files['file'] # 获取上传文件 print(request.values.get("filePath")) fname = secure_filename(f.filename)
ext = fname.rsplit('.', 1)[1] # 获取文件后缀 f.save(os.path.join(file_dir, fname)) # 保存文件到upload目录
if ext == 'zip':
pass
return jsonify({"errno": "", "errmsg": u"success"}) # 下载文件-download-file
@app.route('/df', methods=['GET', 'POST'])
def api_download():
if request.method == 'GET':
fullfilename = request.json['fileName']
print(fullfilename)
filepath = run_path + 'tools/' + fullfilename
print(filepath)
if not os.path.isfile(filepath):
print("nononononono!!!")
return
# 普通下载
# response = make_response(send_from_directory(filepath, fullfilename, as_attachment=True))
# response.headers["Content-Disposition"] = "attachment; filename={}".format(filepath.encode().decode('latin-1'))
# return response # 流式读取
def send_file():
store_path = filepath
with open(store_path, 'rb') as targetfile:
while 1:
data = targetfile.read(1 * 1024 * 1024) # 每次读取1M
if not data:
break
yield data response = Response(send_file(), content_type='application/octet-stream')
response.headers["Content-disposition"] = 'attachment; filename=%s' % fullfilename
return response if __name__ == '__main__':
app.run(debug=True, port=5002, host='0.0.0.0')
# 默认127.0.0.1:5000,这里修改了地址和端口方便自己使用
调用方式:
# coding:utf-8
import requests
from urllib3 import encode_multipart_formdata url = "http://localhost:5002/up"
data = {
"filePath": ""
}
header = {}
data['file'] = ("xx.zip", open(r"./basedir/xx.zip", 'rb').read())
encode_data = encode_multipart_formdata(data)
data = encode_data[0]
header['Content-Type'] = encode_data[1]
try:
result = requests.request(method='POST', url=url, headers=header, data=data, timeout=(3, 100)) if "true" in result.text:
analyse_json = result.json()
print("向服务器发送文件并解压成功")
result_path = analyse_json["data"]
print("服务器端的地址为 {}".format(result_path))
else:
print("向服务器发送文件并解压Failed {}".format(result.text))
except Exception as e:
print("执行发送数据失败.{}".format(e)) #-------------------------------------------- url = "http://localhost:5002/df"
data = {
"fileName": "xx.jar"
} result = requests.request(method="GET", url=url, json=data, stream=True)
f = open(data['fileName'], "wb")
for chunk in result.iter_content(chunk_size=512):
if chunk:
f.write(chunk) #---------------------------------------------
使用curl命令进行发送文件的方式:
curl ${URL} -X POST -F "file=@${app_path}/${APP_NAME}.zip" -F "ip1=${IP}" -F "ip2=${get_ip}" -F "port=${port}" -F "num=${num}"
python flask解决上传下载的问题的更多相关文章
- python day32--struct,文件上传下载
一.struct模块 可以把要发送的数据长度转换成固定长度的字节 struct.pack('i',数据长度) struct.unpack('i',数据长度) 二.上传下载文件作业 server imp ...
- python实现socket上传下载文件-进度条显示
在python的socket编程中,可以实现上传下载文件,并且在下载的时候,显示进度条,具体的流程如下图所示: 1. 服务器端代码如下: [root@python 519]# cat server.p ...
- Ajax+Python flask实现上传文件功能
HTML: <div > <input type="file" name="FileUpload" id="FileUpload&q ...
- python服务器文件上传下载+GUI【tkinter】
大概就是一个通过应用程序来和服务器打交道的这么一个,小东西 1.GUI 用的是tkinter # -*- coding: UTF-8 -*- from tkinter import * import ...
- FLASK实现上传下载功能
#!-*-coding=utf-8-*- # from flask import Flask # # app = Flask(__name__) # # # @app.route('/') # def ...
- python用ftplib上传下载中文报错解决
python中的中文编码一直以来都是一个极为头大的问题,经常抛出编码转换的异常,python中的str和unicode到底是一个什么东西呢?在python中提到unicode,一般指的是unicode ...
- Python socket文件上传下载
python网络编程 程序的目录结构 socketDemo ├── client │ ├── cli.py │ └── local_dir │ └── lianxijiangjie.mp4 ...
- python 实现远端ftp文件上传下载
python 实现ftp上传下载 * 脚本需要传入两个参数,参数1为需要从远端ftp站点下载文件名称,参数2为已知需要下载的文件md5值,文件下载完成后会自动进行md5值校验 * 运行示例 [root ...
- python paramiko实现ssh上传下载执行命令
paramiko ssh上传下载执行命令 序言 最近项目经常需要动态在跳板机上登录服务器进行部署环境,且服务器比较多,每次完成所有服务器到环境部署执行耗费大量时间.为了解决这个问题,根据所学的执行实现 ...
随机推荐
- CodeForces 714E Sonya and Problem Wihtout a Legend(单调数列和DP的小研究)
题意:给你n个数字,每个数字可以加减任何数字,付出变化差值的代价,求最后整个序列是严格单调递增的最小的代价. 首先我们要将这个题目进行转化,因为严格单调下是无法用下面这个dp的方法的,因此我们转化成非 ...
- HDU 5810 Balls and Boxes ——(数学,概率,方差)
官方题解看不太懂,参考了一些人的博客以后自己证明如下: 其中D(X)和E(X)的公式如下(参考自百度百科): 其中 p = 1 / m .(这是每一个单独事件发生的概率期望,在这里单独事件指的是一个球 ...
- Java EE 之 Hibernate异常解决:org.hibernate.exception.SQLGrammarException: could not execute statement
本质原因:配置的Java Bean,由Hibernate自动产生的SQL语句中有语法错误 原因如下: 情况1.存在字段名/表名与数据库关键字冲突 情况2.MySQL5.0以后与MySQL5.0以前事务 ...
- 10.矩形覆盖 Java
题目描述 我们可以用2**1的小矩形横着或者竖着去覆盖更大的矩形.请问用n个21的小矩形无重叠地覆盖一个2n的大矩形,总共有多少种方法? 思路 其实,倒数第一列要么就是1个2**1的矩形竖着放,要么就 ...
- fMRI数据分析处理原理及方法————转自网络
fMRI数据分析处理原理及方法 来源: 整理文件的时候翻到的,来源已经找不到了囧感觉写得还是不错,贴在这里保存. 近年来,血氧水平依赖性磁共振脑功能成像(Blood oxygenation level ...
- "UICollectionView实现带头视图和组的头视图同时存在"实现
实现效果如下: 以前做这效果的界面,总是实现的是section的头视图,因为我一直觉得collectionView是不像UITableView那样有tableHeaderView的,所以每次实现只能是 ...
- 【转】最新版zookeeper配置看这一篇就够了
[From]https://blog.csdn.net/yydriver/article/details/81107954 版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载 ...
- jdk1.8-Vector
一:先看下类的继承关系 UML图如下: 继承关系: ))) ))) grow(minCapacity)) ? ) newCapacity = minCapacity) ) , elementData, ...
- ubuntu安装dockers过程:
1. 先对系统进行更新 1.1 apt-get upgrade 1.2 去中国关于dockers的网站 http://get.daocloud.io/ 1.3 安装docker curl -sSL h ...
- spark map和mapPartitions的区别
package dayo1 import org.apache.spark.{SparkConf, SparkContext} import scala.collection.mutable.Arra ...