成人在线亚洲_国产日韩视频一区二区三区_久久久国产精品_99国内精品久久久久久久

您的位置:首頁技術文章
文章詳情頁

ajax post下載flask文件流以及中文文件名問題

瀏覽:635日期:2022-06-11 17:08:50

ajax post下載文件

后端返回文件流,flask中可使用 return send_file(文件路徑) 返回二進制文件流,在headers中傳送文件相關信息(如文件名)。

前端使用 URL.createObjectURL() 創建創建一個  DOMString URL對象,創建一個 a 節點,將URL對象賦給a節點的 href 屬性,最后調用 click() 方法點擊該 a 節點即可彈出瀏覽器下載框。

展示圖片

方法同上,將 a 改成 img , href 改成 src 即可,將URL對象寫入到目標img標簽的src即可。

另一種方法是后端返回圖片轉base64的字符串,src的值形如 "data:image/svg+xml;base64,${base字符串}" 。(這里的 svg+xml 表示圖片格式是svg,如果是png則改成png)

中文文件名亂碼

http headers中直接傳輸中文文件名,比較簡單的方法是后端進行url轉碼(這里使用python的 urllib.parse.quote ),前端使用 decodeURI() 解碼。

此外還可以設置headers的 Content-Disposition: attachment; filename*=UTF-8""xxxxx ,不過兼容性嘛……麻煩還不如直接urlcode算了,而且也懶得設置 Content-Disposition 了,前端從 Content-Disposition 中取 filename 也是夠麻煩的,會取到一長串字符串然后自己再想辦法取出來 filename= 后面的信息。

代碼如下:

flask

from urllib.parse import quote
@file.route("/download", methods=["POST"])
def download_file():
  filename="xx" #文件名
  filepath="xx/xx" #文件路徑
  res = make_response(send_file(filepath))
  #自定義的一個header,方便前端取到名字
  res.headers["filename"] = quote(filename.encode("utf-8"))
  return res
javascript——以async異步fetch為例:

async function download() {
  const res = await fetch(`http://xxx/file/download`, {
  method: "POST",
  body: JSON.stringify({}), //body里面是要發送的數據
  headers: { "Content-Type": "application/json" },
  responseType: "blob"
 })

 if (res.ok) {
  const blData = await res.blob() //拿到blob數據
  const urlObjData = window.URL.createObjectURL(new Blob([blData])) //創建url對象
  
  //獲取文件 進行下轉碼
  const fileName = decodeURI(fileNameres.headers.get("filename"))
  
  //創建a標簽 點擊a標簽 達到下載目的
  const link = document.createElement("a")
  link.href = urlObjData
  link.download = fileName //下載文件的名字
  document.body.appendChild(link)
  link.click()
  
  document.body.removeChild(link)
  window.URL.revokeObjectURL(urlObjData);
  
  //展示圖片
  //xxx.src=urlObjData
 }
}

ps:flask下載文件---文件流

html:

<a name="downloadbtn" href="/downloadfile/?filename=/root/allfile/123.txt">下載</a>

py:

@app.route("/downloadfile/", methods=["GET", "POST"])
def downloadfile():
  if request.method == "GET":
    fullfilename = request.args.get("filename")
    # fullfilename = "/root/allfile/123.txt"
    fullfilenamelist = fullfilename.split("/")
    filename = fullfilenamelist[-1]
    filepath = fullfilename.replace("/%s"%filename, "")
    #普通下載
    # response = make_response(send_from_directory(filepath, filename, as_attachment=True))
    # response.headers["Content-Disposition"] = "attachment; filename={}".format(filepath.encode().decode("latin-1"))
    #return send_from_directory(filepath, filename, as_attachment=True)
    #流式讀取
    def send_file():
      store_path = fullfilename
      with open(store_path, "rb") as targetfile:
while 1:
  data = targetfile.read(20 * 1024 * 1024)  # 每次讀取20M
  if not data:
    break
  yield data

    response = Response(send_file(), content_type="application/octet-stream")
    response.headers["Content-disposition"] = "attachment; filename=%s" % filename  # 如果不加上這行代碼,導致下圖的問題
    return response

沒有文件名,和文件格式,遇到這種情況,打開F12,查看response.headers 與正常的比較

總結

到此這篇關于ajax post下載flask文件流以及中文文件名的文章就介紹到這了,更多相關ajax post下載flask文件流內容請搜索以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持!

標簽: Ajax
相關文章:
成人在线亚洲_国产日韩视频一区二区三区_久久久国产精品_99国内精品久久久久久久
国产一区二区91| 亚洲视频狠狠| 国产精品护士白丝一区av| 亚洲大片精品永久免费| 国产精品77777| 亚洲第一在线| 欧美日韩精品一区二区三区蜜桃 | 成人免费电影视频| 一区二区国产精品| 日韩一级高清毛片| 亚洲最大的成人av| aaa亚洲精品一二三区| 久久精品二区三区| 精品成人一区二区三区| 午夜精品久久久久久久久久久| 国产91在线看| 亚洲一区综合| 国产欧美一区二区精品久导航 | 久久深夜福利| 久久久欧美精品sm网站| 欧美精品在线视频| 亚洲激情中文1区| 成人h精品动漫一区二区三区| 日韩亚洲精品在线| 91精品午夜视频| 亚洲欧美激情视频在线观看一区二区三区| 国产精品亚洲视频| 91麻豆精品国产自产在线| 国产精品亚洲综合一区在线观看| 日韩亚洲欧美在线观看| 国产91精品一区二区麻豆网站| 精品精品国产高清a毛片牛牛| av午夜精品一区二区三区| 日本一区二区视频在线| 好看的亚洲午夜视频在线| 欧美一级xxx| 成人激情免费视频| 中文字幕的久久| 欧美肥妇free| 国产伦精品一区二区三区免费迷| 欧美日韩国产高清一区二区 | 久久精品国产成人一区二区三区 | 亚洲一区二区三区三| 91视频精品在这里| 欧美亚洲国产一区在线观看网站 | 国产精品一级黄| 久久综合狠狠综合久久综合88 | 精品一区免费av| 久久电影一区| 久久综合综合久久综合| 日韩欧美国产一区在线观看| 精品在线播放免费| 欧美电影免费观看高清完整版在| 国产精品大片| 日韩avvvv在线播放| 国产精品最新自拍| 日本少妇一区二区| 日韩精品一区二区三区中文不卡| 欧美午夜在线视频| 久久久久久久久99精品| 亚洲国产1区| 人妖欧美一区二区| 色婷婷综合久久久| 天天综合网 天天综合色| 欧美日韩国产另类一区| 欧美国产三区| 国产精品天干天干在观线| www.欧美色图| 国产精品的网站| 在线观看精品一区| 青青青爽久久午夜综合久久午夜 | 久久免费电影网| 99精品国产一区二区青青牛奶| 久久精品国产在热久久| 国产亚洲女人久久久久毛片| 成人免费的视频| 亚洲码国产岛国毛片在线| 欧美日韩亚洲综合一区二区三区| 免费在线观看精品| 精品剧情v国产在线观看在线| 国产99久久久国产精品免费看| 欧美激情资源网| 一本大道综合伊人精品热热| 成人精品免费看| √…a在线天堂一区| 国产欧美高清| 国产成人精品三级| 欧美精品一区二区三区久久久 | 免费亚洲电影在线| 亚洲国产成人私人影院tom| 色呦呦一区二区三区| 欧美成人一品| 久久精品国产精品青草| 中文字幕一区二区三区蜜月| 91成人国产精品| 日本不卡一区二区| 久久一二三国产| 色吊一区二区三区| 国内自拍一区| 国产成人av自拍| 亚洲大片一区二区三区| 国产亚洲欧洲997久久综合| 91黄色小视频| 在线精品一区| 成人污污视频在线观看| 五月开心婷婷久久| 国产精品美女一区二区在线观看| 欧美精品v国产精品v日韩精品| 99视频一区| 99riav久久精品riav| 国产丝袜欧美中文另类| 久久人人97超碰人人澡爱香蕉| 欧美激情四色| 亚洲一区二区精品视频| 久久久蜜桃精品| 欧美美女网站色| 免播放器亚洲| 国产激情一区二区三区四区| 亚洲国产精品久久久久秋霞影院| 在线日韩av片| 精品电影一区| 99麻豆久久久国产精品免费优播| 久色婷婷小香蕉久久| 亚洲一区二区三区四区在线观看| 欧美激情一区二区在线| 日韩一区二区在线免费观看| 一本到不卡免费一区二区| 一区二区高清视频| 欧美精品网站| 99久久久无码国产精品| 国产精品资源在线看| 蜜桃av噜噜一区| 精品免费日韩av| 色偷偷一区二区三区| 在线日韩中文| 色综合天天视频在线观看| 亚洲一区二区综合| 国产午夜精品一区二区三区视频 | 一本不卡影院| 欧美视频亚洲视频| 99久久国产免费看| 国产91精品免费| 国产一区二区三区免费在线观看| 日韩电影在线观看电影| 亚洲国产美国国产综合一区二区| 中文字幕一区二区不卡 | 日韩欧美二区三区| 欧美日韩另类一区| 欧美在线啊v一区| 久久一区二区精品| 久久国产精品一区二区三区四区 | 日韩精品专区在线影院观看| 欧美人与性动xxxx| 在线观看av不卡| 久久综合久久久| 石原莉奈在线亚洲三区| 日本韩国欧美在线| 亚洲一卡久久| 国产一区二区三区久久久| 美女一区二区视频| 日产欧产美韩系列久久99| 亚洲国产成人精品视频| 亚洲免费在线电影| 曰韩精品一区二区| 亚洲一区二区三区影院| 亚洲午夜免费电影| 亚洲一区二区黄色| 亚洲第一搞黄网站| 五月激情六月综合| 免费在线观看一区| 激情欧美一区二区| 一区二区三区在线视频播放| 国产精品国产自产拍高清av王其 | 欧美不卡视频一区| 久久亚洲捆绑美女| 国产女人18水真多18精品一级做| 国产欧美精品日韩区二区麻豆天美 | 日本久久电影网| 欧美午夜免费电影| 欧美日韩亚洲综合在线| 91精品国产一区二区| 国产精品一区毛片| 国产日韩一区欧美| 91蜜桃网址入口| 99re视频精品| 欧美日韩中文| 亚洲第一在线综合在线| 日韩午夜视频在线观看| 国产精品欧美日韩一区| 小嫩嫩精品导航| 欧美在线视频全部完| 91麻豆精品国产91久久久使用方法 | 91国产免费看| 欧美日韩国产精品自在自线| 欧美一级国产精品| 久久麻豆一区二区| 国产精品欧美经典| 一二三区精品视频| 日本在线不卡视频| 国产美女一区二区三区|