如何通过React中的API下载文件?

时间:2019-05-20 11:03:33

标签: javascript reactjs axios

在我的react应用程序中,我有一个具有文件下载按钮的组件,用于下载来自后端的文件。我在AXIOS通话中使用AJAX问题是,下载文件后,文件已损坏。我正在下载png文件和pdf文件。当我打开下载的图像时,它说它已损坏,并且下载的pdf仅显示白色背景。如何正确下载文件?

**组件:**

import API from "../../api/api";

class DocumentsTable extends React.Component {
  constructor(props) {
    super(props);
    this.state = {
      fileId: 4
    };
    this.downloadMapById = this.downloadMapById.bind(this);
  }

  downloadMapById() {
    const type = 1;
    const file_id = this.state.fileId;

    const FileDownload = require("js-file-download");

    API.post("project/files/download", { file_id, type })
      .then(({ data }) => {
        FileDownload(data, "myImage.png");
        console.log("success!", data);
      })
      .catch(err => {
        console.log("AXIOS ERROR: ", err);
      });
  }

  render() {
    return <button onClick={() => this.downloadMapById}>Download</button>;
  }
}

API文件:

import axios from "axios";

const token = localStorage.getItem("token");

export default axios.create({
  baseURL: `${process.env.REACT_APP_BACKEND_BASE_URL}/api/v1/`,
  headers: {
    Authorization: "Bearer " + token,
    "Content-Type": "application/json",
    Accept: "application/json"
  }
});

1 个答案:

答案 0 :(得分:1)

由于我无法添加评论,因此发布为答案。 我尝试过同样的事情,并在此link中发布了同样的问题。

对于 post 方法,我可以通过 fetch 获得成功,如下所示。

 fetch("url",
        { 
            method: "POST",
            headers: { "Content-Type": "application/json",'Authorization': 'Bearer ' + window.localStorage["Access_Token"]},
            body:data
        }).then(response => response.blob()).then(response => ...*your code for download*... )

您正在损坏文件,因为您没有收到 blob arraybuffer