前不久公司有个需求,把时序数据库中的日志下载到本地,大家都知道,数据库里的数据都是存在数据库里的(废话),想把他下载到客户的本地, 有的同学第一反应是: 只有文件才能下载,所以大多数同学会想到先把数据从数据库中读出来,然后写入到服务器中的某个文件夹下生成文件, 然后再下载。其实这是非常不效率的方法,最简单的方法是,我们从数据库中读取到文件后,直接以流的形式让用户去下载。
这里我拿python flask框架来做例子,其实非常简单,步骤一共有3个
1: 取出数据, 我们默认为json文件吧
2: 在response中加入指定的header
3: 将数据返回.
那么废话少说,我们直接上代码:
# coding:utf-
8
import json
from flask
import Flask, make_response
app = Flask(__name__)
@app.route(
'/download', methods=[
"GET"])
def download():user = {
'name':
'dewei',
'age':
33}
data = json.dumps(user)
response = make_response(
data)
response.headers[
'