У меня проблема с загрузкой файла xlsx из API rest JS - PullRequest
0 голосов
/ 03 февраля 2020

Я работаю над ReactJs. У меня есть кнопка, которая загружает файл Excel, предоставленный из API REST. Проблема в том, что я читаю весь контент из ответа, а затем загружаю всю эту информацию в строку.

Но я был пробуя разные вещи, и у меня всегда одна и та же проблема, когда я пытаюсь открыть файл в Excel, он показывает сообщение о том, что файл поврежден. Это мой код:

export const getFilesFromApi = (path, callBack, contentType) => apiFileCalls({ path, method: 'GET', callBack, contentType: contentType || 'text/plain' });

export const apiFileCalls = ({ path, callBack, data, method, contentType, attachFiles = [], additionalHeaders = [] }) => {
    debugger;
    new Promise(() => {
        const request = superagent(method, path);
        request.set('Access-Control-Allow-Origin', '*');
        if (contentType) {
            request.set('Content-Type', contentType);
        }
        const accessToken = getCookie_accessToken();
        if (accessToken) {
            request.set('Authorization', `Bearer ${accessToken}`);
        }
        if (data) {
            request.send(data);
        }

        additionalHeaders.forEach((header) => request.set(header.name, header.value));
        attachFiles.forEach((file) => request.attach(file.fieldName, file.file));

        request.query().then((res) => callBack(res.text)).catch((error) => {
            if (error.status !== 401) {
                callBack(true, error.response);
            }
        });
    });
};
export const downloadFile = (content, fileName) => {
    debugger;
    const urlrtMP = window.URL.createObjectURL(new Blob([ content ]));
    const link = document.createElement('a');
    link.href = urlrtMP;
    link.setAttribute('download', fileName);
    link.click();
};

Любая помощь? Большое спасибо

1 Ответ

0 голосов
/ 03 февраля 2020

Вы должны использовать responseType ('blob') для получения содержимого Blob.

Ссылка: https://visionmedia.github.io/superagent/#binary

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...