Объедините большие двоичные объекты Azure (PDF-файлы) в один большой двоичный объект и загрузите его пользователю через C# ASP.NET

0

Вопрос

У меня есть ASP.NET Веб-приложение Azure, написанное на C#, которое включает в себя загрузку пользователем различных PDF-файлов в хранилище больших двоичных объектов Azure. Я бы хотел, чтобы пользователь позже загрузил объединенный PDF-файл, включающий ранее загруженные большие двоичные объекты в определенном порядке. Есть идеи о том, как лучше всего этого добиться?

asp.net azure blob c#
2021-11-21 19:18:14
1

Лучший ответ

1

Вот 2 обходных пути, которые вы можете попробовать

  1. Использование функций Azure.
  2. Загрузите PDF-файлы из большого двоичного объекта Azure на свой локальный компьютер, а затем объедините их.

Использование функций Azure

  1. Создайте проект функции azure и используйте триггер HTTP.
  2. Убедитесь, что вы установили приведенные ниже пакеты, прежде чем приступать к кодированию.
  3. Создайте код функции.
  4. Создайте функцию Azure на портале.
  5. Опубликуйте код.

Мы готовы приступить к написанию кода. Нам нужны два файла:

  1. ResultClass.cs – возвращает объединенные файлы в виде списка.
  2. Function1.cs – CCode, который берет имена файлов из URL-адреса, захватывает их из учетной записи хранения, объединяет их в один и возвращает URL-адрес для загрузки.

ResultClass.cs

using System;
using System.Collections.Generic;

namespace FunctionApp1
{

    public class Result
    {

        public Result(IList<string> newFiles)
        {
            this.files = newFiles;
        }

        public IList<string> files { get; private set; }
    }
}

Функция 1.cs

using System;
using System.Collections.Generic;
using System.IO;
using System.Net.Http;
using System.Threading.Tasks;
using Microsoft.AspNetCore.Http;
using Microsoft.AspNetCore.Mvc;
using Microsoft.Azure.WebJobs;
using Microsoft.Azure.WebJobs.Extensions.Http;
using Microsoft.Extensions.Logging;
using Microsoft.Extensions.Configuration;
using Microsoft.WindowsAzure.Storage.Blob;
using Newtonsoft.Json;
using PdfSharp.Pdf;
using PdfSharp.Pdf.IO;

namespace FunctionApp1
{
    public class Function1
    {

        static Function1()
        {

            // This is required to avoid the "No data is available                         for encoding 1252" exception when saving the PdfDocument
System.Text.Encoding.RegisterProvider(System.Text.CodePagesEncodingProvider.Instance);

        }

        [FunctionName("Function1")]
        public async Task<Result> SplitUploadAsync(
            [HttpTrigger(AuthorizationLevel.Anonymous, "post", Route = null)] HttpRequestMessage req,
            //container where files will be stored and accessed for retrieval. in this case, it's called temp-pdf
            [Blob("temp-pdf", Connection = "")] CloudBlobContainer outputContainer,
            ILogger log)
        {
            //get query parameters

            string uriq = req.RequestUri.ToString(); 
            string keyw = uriq.Substring(uriq.IndexOf('=') + 1);

            //get file name in query parameters
            String fileNames = keyw.Split("mergepfd&filenam=")[1];

            //split file name
            string[] files = fileNames.Split(',');

            //process merge
            var newFiles = await this.MergeFileAsync(outputContainer, files);

            return new Result(newFiles);

        }

        private async Task<IList<string>> MergeFileAsync(CloudBlobContainer container, string[] blobfiles)
        {
            //init instance
            PdfDocument outputDocument = new PdfDocument();

            //loop through files sent in query
            foreach (string fileblob in blobfiles)
            {
                String intfile = $"" + fileblob;

                // get file
                CloudBlockBlob blob = container.GetBlockBlobReference(intfile);

                using (var memoryStream = new MemoryStream())
                {
                    await blob.DownloadToStreamAsync(memoryStream);

                    //get file content
                    string contents = blob.DownloadTextAsync().Result;
                   
                    //open document
                    var inputDocument = PdfReader.Open(memoryStream, PdfDocumentOpenMode.Import);

                    //get pages
                    int count = inputDocument.PageCount;
                    for (int idx = 0; idx < count; idx++)
                    {
                        //append
                        outputDocument.AddPage(inputDocument.Pages[idx]);
                    }


                }
            }


            var outputFiles = new List<string>();
            var tempFile = String.Empty;

            //call save function to store output in container
            tempFile = await this.SaveToBlobStorageAsync(container, outputDocument);

            outputFiles.Add(tempFile);

            //return file(s) url
            return outputFiles;
        }

        private async Task<string> SaveToBlobStorageAsync(CloudBlobContainer container, PdfDocument document)
        {

            //file name structure
            var filename = $"merge-{DateTime.Now.ToString("yyyyMMddhhmmss")}-{Guid.NewGuid().ToString().Substring(0, 4)}.pdf";

            // Creating an empty file pointer
            var outputBlob = container.GetBlockBlobReference(filename);

            using (var stream = new MemoryStream())
            {
                //save result of merge
                document.Save(stream);
                await outputBlob.UploadFromStreamAsync(stream);
            }

            //get sas token
            var sasBlobToken = outputBlob.GetSharedAccessSignature(new SharedAccessBlobPolicy()
            {
                SharedAccessExpiryTime = DateTime.UtcNow.AddMinutes(5),
                Permissions = SharedAccessBlobPermissions.Read
            });

            //return sas token
            return outputBlob.Uri + sasBlobToken;
        }
    }
}

Загрузите PDF-файлы из большого двоичного объекта Azure на свой локальный компьютер, а затем объедините их

 internal static void combineNormalPdfFiles()
        {
            String inputFilePath1 = @"C:\1.pdf";
            String inputFilePath2 = @"C:\2.pdf";
            String inputFilePath3 = @"C:\3.pdf";
            String outputFilePath = @"C:\Output.pdf";
            String[] inputFilePaths = new String[3] { inputFilePath1, inputFilePath2, inputFilePath3 };

            // Combine three PDF files and output.
            PDFDocument.CombineDocument(inputFilePaths, outputFilePath);
        }

СПИСОК ЛИТЕРАТУРЫ:

  1. Функция Azure для объединения больших двоичных объектов PDF в учетной записи хранилища Azure (контейнер больших двоичных объектов)
  2. C# Merge PDF SDK: Объединение, объединение PDF-файлов в C#.net, ASP.NET, MVC, Ajax, WinForms, WPF
2021-11-22 05:18:46

SwethaKandikonda-MT, это было удивительное решение, которое я успешно включил в свой веб-сайт. Моя огромная искренняя благодарность вам за отклик! Я не работал с функциями Azure до вашего комментария, но теперь я знаю гораздо больше. Заказ и компиляция загруженных PDF-файлов azure blob в один PDF-файл были тем, от чего я почти отказался до этого.
Wallstreetguy

Если мой ответ вам помог, вы можете принять его в качестве ответа (нажмите на галочку рядом с ответом, чтобы переключить его с серого на заполнение). Это может быть полезно для других членов сообщества. Спасибо
SwethaKandikonda-MT

На других языках

Эта страница на других языках

Italiano
..................................................................................................................
Polski
..................................................................................................................
Română
..................................................................................................................
한국어
..................................................................................................................
हिन्दी
..................................................................................................................
Français
..................................................................................................................
Türk
..................................................................................................................
Česk
..................................................................................................................
Português
..................................................................................................................
ไทย
..................................................................................................................
中文
..................................................................................................................
Español
..................................................................................................................
Slovenský
..................................................................................................................