Série Azure Blobs (PDFs) em um Blob e baixe para o usuário através de C# ASP.NET

0

Pergunta

Eu tenho um ASP.NET Azure web aplicativo escrito em C# que envolve o usuário upload de diferentes pdfs em Azure Blob storage. Eu gostaria de o usuário para o download mais tarde um combinado PDF inclusivo previamente carregados blobs em uma ordem específica. Qualquer idéia sobre a melhor forma de fazer isso?

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

Melhor resposta

1

Aqui estão 2 soluções que você pode tentar

  1. Uso do Azure Funções.
  2. Download de seus arquivos pdf a partir de Azure Blob para o seu computador local e, em seguida, juntá-las.

Uso do Azure Funções

  1. Criar uma azure função de projeto e usar o HTTP Gatilho.
  2. Certifique-se de instalar os pacotes abaixo antes de começar com a codificação.
  3. Criar o código de Função.
  4. Criar Azure função no portal.
  5. Publicar o código.

Estamos prontos para começar a escrever código. Precisamos de dois arquivos:

  1. ResultClass.cs – retorna o arquivo mesclado(s) como uma lista.
  2. Function1.cs – CCode que leva os nomes de ficheiro a partir do URL, agarra-los a partir da conta de Armazenamento, mescla-los em um só, e retorna uma URL de download.

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; }
    }
}

Function1.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;
        }
    }
}

Download de seus arquivos pdf a partir de Azure Blob para o seu computador local e, em seguida, juntá-las

 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);
        }

REFERÊNCIAS:

  1. Azure Função para combinar PDF Blobs no Azure Conta de Armazenamento Blob (recipiente)
  2. C# Merge PDF SDK: Juntar, combinar arquivos PDF em C#.net, ASP.NET, MVC, Ajax, WinForms, WPF
2021-11-22 05:18:46

SwethaKandikonda-MT, esta foi uma solução incrível e que eu tenho incorporadas com sucesso em meu site. Meus sinceros agradecimentos a você para de responder! Eu não tinha trabalhado com Azure Funções, antes do seu comentário, mas eu sei muito mais agora. Ordenação e compilar carregado azure blob PDFs em um PDF foi algo que eu quase desisti, até que este.
Wallstreetguy

Se minha resposta o ajudou, você pode aceitá-lo como uma resposta (Clique na marca de seleção ao lado de resposta para desativá-lo a partir de cinzento para preencher). Isso pode ser útil para outros membros da comunidade. Obrigado
SwethaKandikonda-MT

Em outros idiomas

Esta página está em outros idiomas

Русский
..................................................................................................................
Italiano
..................................................................................................................
Polski
..................................................................................................................
Română
..................................................................................................................
한국어
..................................................................................................................
हिन्दी
..................................................................................................................
Français
..................................................................................................................
Türk
..................................................................................................................
Česk
..................................................................................................................
ไทย
..................................................................................................................
中文
..................................................................................................................
Español
..................................................................................................................
Slovenský
..................................................................................................................