Записать файл байтового массива в OneDrive

Итак, я понял, как взять файл из OneDrive для бизнеса и записать его в локальный каталог на моем компьютере с помощью следующего кода:

    public static async Task GetFileAsync()
    {
        var (authResult, message) = await Authentication.AquireTokenAsync();
        var httpClient = new HttpClient();
        HttpResponseMessage response;
        var request = new HttpRequestMessage(HttpMethod.Get, MainPage.fileurl);
        request.Headers.Authorization = new System.Net.Http.Headers.AuthenticationHeaderValue("Bearer", authResult.AccessToken);
        response = await httpClient.SendAsync(request);
        byte[] fileBytes = await response.Content.ReadAsByteArrayAsync();
        StorageLibrary videoLibrary = await StorageLibrary.GetLibraryAsync(KnownLibraryId.Videos);
        string saveFolder = videoLibrary.SaveFolder.Path;
        string genName = App.Generator;
        genName = genName.Replace(" ", "-");
        string saveFileName = App.Date + "-" + App.StartTime + "-" + App.IBX + "-" + genName + ".xlsx";
        saveLocation = saveFolder + "\\" + saveFileName;

        using (MemoryStream stream = new MemoryStream())
        {
            stream.Write(fileBytes, 0, (int)fileBytes.Length);
            using (spreadsheetDoc = SpreadsheetDocument.Open(stream, true))
            {
                await Task.Run(() =>
                {
                    File.WriteAllBytes(saveLocation, stream.ToArray());
                    return TaskStatus.RanToCompletion;
                });
            }
        }
    }

Как только я сохранил файл на моем локальном компьютере, я смог успешно отредактировать файл и сохранить изменения.

Я понял, как получить его в байтовый массив и как удалить отредактированный файл в локальной папке после создания массива. Теперь я хочу записать этот новый отредактированный файл (массив байтов) обратно в подпапку OneDrive.

Код, который у меня есть, выглядит следующим образом:

    public static async Task PutFileAsync()
    {
        string genName = App.Generator;
        genName = genName.Replace(" ", "-");
        StorageLibrary videoLibrary = await StorageLibrary.GetLibraryAsync(KnownLibraryId.Videos);
        string readFolder = videoLibrary.SaveFolder.Path;
        StorageFolder videoFolder = await StorageFolder.GetFolderFromPathAsync(readFolder);
        string readFileName = App.Date + "-" + App.StartTime + "-" + App.IBX + "-" + genName + ".xlsx";
        StorageFile readFile = await videoFolder.GetFileAsync(readFileName);            

Внесены некоторые изменения:

        var (authResult, message) = await Authentication.AquireTokenAsync();
        var httpClient = new HttpClient();
        HttpResponseMessage response;
        string posturl = MainPage.spfileurl + readFile.Name + ":/content";
        var content = JsonConvert.SerializeObject(readFile);
        var request = new HttpRequestMessage(HttpMethod.Put, posturl);
        request.Headers.Authorization = new System.Net.Http.Headers.AuthenticationHeaderValue("Bearer", authResult.AccessToken);
        request.Content = new StringContent(content, Encoding.UTF8, "application/json");
        response = await httpClient.SendAsync(request);
        var responseString = await response.Content.ReadAsStringAsync();
        await Task.Run(() =>
        {
            File.Delete(readFile.Path);
            return TaskStatus.RanToCompletion;
        });

И эта последняя часть также привязана к еще один мой пост.

первая проблема .... используйте правильный URL.

CET 09.09.2018 21:57
Стоит ли изучать PHP в 2023-2024 годах?
Стоит ли изучать PHP в 2023-2024 годах?
Привет всем, сегодня я хочу высказать свои соображения по поводу вопроса, который я уже много раз получал в своем сообществе: "Стоит ли изучать PHP в...
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
В JavaScript одним из самых запутанных понятий является поведение ключевого слова "this" в стрелочной и обычной функциях.
Приемы CSS-макетирования - floats и Flexbox
Приемы CSS-макетирования - floats и Flexbox
Здравствуйте, друзья-студенты! Готовы совершенствовать свои навыки веб-дизайна? Сегодня в нашем путешествии мы рассмотрим приемы CSS-верстки - в...
Тестирование функциональных ngrx-эффектов в Angular 16 с помощью Jest
В системе управления состояниями ngrx, совместимой с Angular 16, появились функциональные эффекты. Это здорово и делает код определенно легче для...
Концепция локализации и ее применение в приложениях React ⚡️
Концепция локализации и ее применение в приложениях React ⚡️
Локализация - это процесс адаптации приложения к различным языкам и культурным требованиям. Это позволяет пользователям получить опыт, соответствующий...
Пользовательский скаляр GraphQL
Пользовательский скаляр GraphQL
Листовые узлы системы типов GraphQL называются скалярами. Достигнув скалярного типа, невозможно спуститься дальше по иерархии типов. Скалярный тип...
0
1
216
1
Перейти к ответу Данный вопрос помечен как решенный

Ответы 1

Ответ принят как подходящий

Вам нужно передать строку json / чистый текст в качестве тела запроса, но не двоичного массива (в вашем случае просто прочитайте фактическое содержимое локального файла и передайте содержимое в json).

Если вы обновите содержимое файла, вы можете использовать обновить api

Другой способ: сначала удалять старый файл на Диске, а загрузить последний.

Добавьте рабочий код на MVC на основе вашего кода (Ключевой момент: request.Content = новый ByteArrayContent) :

 // Initialize the GraphServiceClient.
            GraphServiceClient graphClient = SDKHelper.GetAuthenticatedClient();

            var httpClient = new HttpClient();
            HttpResponseMessage response;
            //string posturl = MainPage.spfileurl + readFile.Name + ":/content";
            string posturl = "https://graph.microsoft.com/v1.0/me/drive/root:/Test.docx:/content";
            //System.IO.FileStream file = System.IO.File.Open(@"D:\TestDocs\Allin.docx", FileMode.Open);             
            //string text= System.IO.File.ReadAllText(@"D:\TestDocs\Allin.docx",Encoding.Unicode);
            //var content = JsonConvert.SerializeObject(file);
            var request1 = new HttpRequestMessage(HttpMethod.Put, posturl);
            string accessToken = await SampleAuthProvider.Instance.GetUserAccessTokenAsync();
            request1.Headers.Authorization = new System.Net.Http.Headers.AuthenticationHeaderValue("Bearer", accessToken);
            //request1.Content = new StringContent(content, Encoding.UTF8, "application/json");
            request1.Content = new ByteArrayContent(System.IO.File.ReadAllBytes(@"D:\TestDocs\Allin.docx"));//  StringContent(text, Encoding.UTF8); 
            response = await httpClient.SendAsync(request1);
            var responseString = await response.Content.ReadAsStringAsync();
            await Task.Run(() =>
            {
                // System.IO.File.Delete(readFile.Path);
                return TaskStatus.RanToCompletion;
            });

Я сам обсуждал эту часть этим утром сегодня утром.

CET 09.09.2018 16:31

Итак, теперь у меня есть «файл», идущий в OneDrive. Однако полученный файл имеет 526 байт и поврежден. Размер файла на жестком диске составляет 38 КБ, и он работает нормально. Я уверен, что это как-то связано с сериализацией файла.

CET 09.09.2018 22:22

Другие вопросы по теме