gpt4 book ai didi

javascript - 如何在 React 中通过 API 下载文件?

转载 作者:行者123 更新时间:2023-11-29 18:42:12 25 4
gpt4 key购买 nike

在我的 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"
}
});

最佳答案

由于我无法添加评论,所以张贴为答案。我已经尝试过同样的事情并在此 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*... )

您收到的文件已损坏,因为您没有以 blobarraybuffer 形式接收内容。

关于javascript - 如何在 React 中通过 API 下载文件?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56219640/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com