Задать вопрос
@Denis_Lebedinsky

Загрузка файла на Яндекс Диск REST API?

Чтобы загрузить файл на Диск, необходимо:

Запросить URL для загрузки.
Загрузить файл по полученному адресу.

https://tech.yandex.ru/disk/api/reference/upload-d...

Я получаю адрес и делаю такой запро:
axios.put(url,
        {
           headers: {
           'Accept': '*/*',
           'Content-Type': 'application/x-www-form-urlencoded',
           'Expect': '100-continue',
           'Content-Length': size
        },
        data: file
    })
        .then(res => res.status)
        .catch(error => {
            throw error
        });


Как бы я не эксперементировал с заголовками, получаю вот такую ошибку CORS

Access to XMLHttpRequest at 'https://uploader38o.disk.yandex.net/upload-target/...' from origin 'localhost:3000' has been blocked by CORS policy: Request header field Authorization is not allowed by Access-Control-Allow-Headers in preflight response.


5bd462b5c3e91913248415.jpeg

В документации нет примера, лишь ссылка.
Как правильно составить запрос.?
  • Вопрос задан
  • 1815 просмотров
Подписаться 2 Простой 4 комментария
Решения вопроса 1
@Denis_Lebedinsky Автор вопроса
Проблема решена, я передавал base64, а нужно передавать blob
вот функция запроса и преобразования в blob. file - это данные из Filereader (reader.result)
export const upload_file_api = (url, file) => {
    const parts = file.split(',');
    const typep = parts[0];
    const base64Data = parts[1];
    const type = typep.split(';')[0].split(':')[1];
    const blobfile = b64toBlob(base64Data, type);

    delete axios.defaults.headers.common['Authorization'];
    axios.defaults.headers.common['Content-Type'] = 'application/octet-stream';
    return axios.put(url, blobfile)
        .then(res => res.status)
        .catch(error => {
            throw error
        });
};

function b64toBlob(b64Data, contentType, sliceSize) {
    contentType = contentType || '';
    sliceSize = sliceSize || 512;

    var byteCharacters = atob(b64Data);
    var byteArrays = [];

    for (var offset = 0; offset < byteCharacters.length; offset += sliceSize) {
        var slice = byteCharacters.slice(offset, offset + sliceSize);

        var byteNumbers = new Array(slice.length);
        for (var i = 0; i < slice.length; i++) {
            byteNumbers[i] = slice.charCodeAt(i);
        }

        var byteArray = new Uint8Array(byteNumbers);

        byteArrays.push(byteArray);
    }

    var blob = new Blob(byteArrays, {type: contentType});
    return blob;
}
Ответ написан
Комментировать
Пригласить эксперта
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Похожие вопросы