前端异步+token下载文件

首先,需要登录的时候把token塞入localStorage里面

js 复制代码
localStorage.setItem('token', data.token);

再写一个公用方法来下载文件(基于ts)

逻辑就是先发一个请求,返回成功后,创建一个a标签,然后点击它

ts 复制代码
// 下载文件
export const download = (link: string, filename: string) => {
  const xhr = new XMLHttpRequest();
  // POST请求,link,async(是否异步)
  xhr.open("POST", link, true);
  // //设置请求头参数的方式,如果没有可忽略此行代码
  xhr.setRequestHeader("token", window?.localStorage?.getItem("token"));
  // //设置响应类型为 blob
  xhr.responseType = "blob";
  // //关键部分
  xhr.onload = function() {
    //   //如果请求执行成功
    if (this.status === 200) {
      const blob = this.response;
      // 创建一个a标签
      const a = document.createElement("a");
      // blob.type = "application/octet-stream";
      // 创键临时url对象
      const url = window.URL.createObjectURL(new Blob([blob]));
      a.href = url;
      a.download = filename;
      // 点击a标签
      a.click();
      // 释放之前创建的URL对象
      window.URL.revokeObjectURL(link);
    }
  };
  // //发送请求
  xhr.send();
}

以下为测试(基于React)

ts 复制代码
		<Button
            onClick={() => {
        // currentPage、pageSize是分页信息,id、name是查询信息
              const link = `localhost:8080/url?currentPage=${searchParams.currentPage}&pageSize=${searchParams.pageSize}${searchParams.id !== undefined ? `&id=${searchParams.id}` : ""}${searchParams.name !== undefined ? `&name=${searchParams.name}` : ""}`
              download(link, "信息.xlsx")
            }}
            key="download"
            target='_blank'
          >
            <CloudDownloadOutlined /> 导出本页
          </Button>
相关推荐
云空几秒前
《解锁 Python 数据挖掘的奥秘》
开发语言·python·数据挖掘
一个处女座的程序猿O(∩_∩)O9 分钟前
完成第一个 Vue3.2 项目后,这是我的技术总结
前端·vue.js
mubeibeinv9 分钟前
项目搭建+图片(添加+图片)
java·服务器·前端
青莳吖11 分钟前
Java通过Map实现与SQL中的group by相同的逻辑
java·开发语言·sql
逆旅行天涯16 分钟前
【Threejs】从零开始(六)--GUI调试开发3D效果
前端·javascript·3d
Buleall18 分钟前
期末考学C
java·开发语言
重生之绝世牛码20 分钟前
Java设计模式 —— 【结构型模式】外观模式详解
java·大数据·开发语言·设计模式·设计原则·外观模式
小蜗牛慢慢爬行26 分钟前
有关异步场景的 10 大 Spring Boot 面试问题
java·开发语言·网络·spring boot·后端·spring·面试
Algorithm157636 分钟前
云原生相关的 Go 语言工程师技术路线(含博客网址导航)
开发语言·云原生·golang
m0_7482552637 分钟前
easyExcel导出大数据量EXCEL文件,前端实现进度条或者遮罩层
前端·excel