c# - 下载的 Google 云端硬盘文件损坏 c#

标签 c# .net google-api google-drive-api google-api-dotnet-client

我正在编写一个程序来下载并保存我的 Google 云端硬盘中的所有数据。问题是,当文件保存时,它的原始大小会增加(例如,一个大小为 287KB 的 .xls 文件被保存为 87411KB 大小),并且我无法打开它,因为它说它已损坏。大多数文件是 .xls 和 .xlsx 文件。

我关注了this教程以及 Google API 文档。

现在我正在使用以下代码:

public static void GetFilesFromDrive()
        {
            UserCredential credential;

            using (var stream =
                new FileStream("credentials.json", FileMode.Open, FileAccess.Read))
            {
                // The file token.json stores the user's access and refresh tokens, and is created
                // automatically when the authorization flow completes for the first time.
                string credPath = "token.json";
                credential = GoogleWebAuthorizationBroker.AuthorizeAsync(
                    GoogleClientSecrets.Load(stream).Secrets,
                    Scopes,
                    "user",
                    CancellationToken.None,
                    new FileDataStore(credPath, true)).Result;
                Console.WriteLine("Credential file saved to: " + credPath);
            }

            // Create Drive API service.
            var service = new DriveService(new BaseClientService.Initializer()
            {
                HttpClientInitializer = credential,
                ApplicationName = ApplicationName,
            });

            // Define parameters of request.
            FilesResource.ListRequest listRequest = service.Files.List();
            listRequest.PageSize = 400;
            listRequest.Fields = "nextPageToken, files(id, name)";

            // List files.
            IList<Google.Apis.Drive.v3.Data.File> files = listRequest.Execute()
                .Files;
            Console.WriteLine("Files:");


            String path = copypath;
            var jetStream = new System.IO.MemoryStream();

            if (files != null && files.Count > 0)
            {
                foreach (var file in files)
                {
                    Console.WriteLine("{0} ({1})", file.Name, file.Id);
                    FilesResource.GetRequest request = new FilesResource.GetRequest(service, file.Id);
                    //ExportRequest(service, file.Id, "application/vnd.google-apps.file");
                    //(service, file.Id);
                    string pathforfiles = path + file.Name.ToString();

                    request.MediaDownloader.ProgressChanged += (Google.Apis.Download.IDownloadProgress progress) =>
                    {
                        switch (progress.Status)
                        {
                            case Google.Apis.Download.DownloadStatus.Downloading:
                                {
                                    Console.WriteLine(progress.BytesDownloaded);
                                    break;
                                }
                            case Google.Apis.Download.DownloadStatus.Completed:
                                {
                                    Console.WriteLine("Download complete.");
                                    using (System.IO.FileStream file = new System.IO.FileStream(pathforfiles, System.IO.FileMode.Create, System.IO.FileAccess.Write))
                                    {
                                        jetStream.WriteTo(file);
                                    }
                                    break;
                                }
                            case Google.Apis.Download.DownloadStatus.Failed:
                                {
                                    Console.WriteLine("Download failed.");
                                    break;
                                }
                        }
                    };

                    request.DownloadWithStatus(jetStream);

                }
            }
            else
            {
                Console.WriteLine("No files found.");
            }
            //Console.Read();
        }

最佳答案

看起来你没有休息内存流。尝试将 var jetStream = new System.IO.MemoryStream(); 移动到 foreach 中。

if (files != null && files.Count > 0)
{
    foreach (var file in files)
    {
        var jetStream = new System.IO.MemoryStream();

        Console.WriteLine("{0} ({1})", file.Name, file.Id);
        FilesResource.GetRequest request = new FilesResource.GetRequest(service, file.Id);
        //ExportRequest(service, file.Id, "application/vnd.google-apps.file");
        //(service, file.Id);
        string pathforfiles = path + file.Name.ToString();

        request.MediaDownloader.ProgressChanged += (Google.Apis.Download.IDownloadProgress progress) =>
        {
            switch (progress.Status)
            {
                case Google.Apis.Download.DownloadStatus.Downloading:
                    {
                        Console.WriteLine(progress.BytesDownloaded);
                        break;
                    }
                case Google.Apis.Download.DownloadStatus.Completed:
                    {
                        Console.WriteLine("Download complete.");
                        using (System.IO.FileStream file = new System.IO.FileStream(pathforfiles, System.IO.FileMode.Create, System.IO.FileAccess.Write))
                        {
                            jetStream.WriteTo(file);
                        }
                        break;
                    }
                case Google.Apis.Download.DownloadStatus.Failed:
                    {
                        Console.WriteLine("Download failed.");
                        break;
                    }
            }
        };

        request.DownloadWithStatus(jetStream);
    }
}

关于c# - 下载的 Google 云端硬盘文件损坏 c#,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/65682309/

相关文章:

flutter - 如何使用Flutter访问Google Drive appdata文件夹文件?

C# 正则表达式转义某些字符

c# - 执行SSIS包

.net - 在 64 位操作系统上以 32 位运行 AnyCPU 应用程序

oauth-2.0 - 从本地主机发送请求时,Google Oauth2 redirect_uri_mismatch

Android Google Play/Drive Api

c# - 如何以编程方式从 Google 驱动器中的 "share with me"中删除文件

c# - Emgu CV 无法从视频中获取所有帧

c# - 在 Azure 中将 tuespechkin 与 MVC 项目结合使用

php - 创建一个 'robot' 来填充一些页面的表单