Am o ASP.NET Azure aplicație web scrisă în C# care implică utilizatorului încărcarea diferite pdf-uri în Azure Blob storage. Aș vrea utilizatorul pentru a descărca mai târziu, un combinat de PDF, inclusiv încărcate anterior blobs într-o anumită ordine. Orice idee pe cel mai bun mod de a realiza acest lucru?
1
Aici sunt 2 soluții pe care le puteți încerca
- Utilizarea de Azur Funcții.
- Descărcați fișierele pdf de Azure Blob la computerul local, apoi îmbinați-le.
Utilizarea de Azur Funcții
- Creați un azure funcție de proiect și de a folosi HTTP Trăgaci.
- Asigurați-vă că instalați pachetele de mai jos înainte de a începe de codificare.
- A crea Funcția de cod.
- Crea Azure funcție în portal.
- Publica codul.
Suntem gata pentru a începe scrierea de cod. Avem nevoie de două fișiere:
- ResultClass.cs – returnează fuzionat fișier(e) ca o listă.
- Function1.cs – CCode care ia numele de fișiere din URL-ul, ia-le de pe cont de Stocare, le combină într-o singură, și returnează un download 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; }
}
}
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;
}
}
}
Descărcați fișierele pdf de Azure Blob la computerul local, apoi îmbinați-le
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);
}
REFERINȚE:
SwethaKandikonda-MT, aceasta a fost o soluție uimitoare și una care trebuie încorporată cu succes în site-ul meu. Multele mele sincere mulțumiri pentru răspuns! Nu am lucrat cu Azure Funcții înainte de a comenta, dar știu atât de mult mai mult acum. Comanda și compilarea încărcate azure blob Pdf-uri într-un singur PDF a fost ceva aproape am renunțat la asta.
Wallstreetguy
Dacă răspunsul meu te-a ajutat, te poate accepta ca un răspuns (faceți Clic pe bifa de lângă răspunsul pentru a comuta de culoare gri pentru a umple). Acest lucru poate fi util pentru alți membri ai comunității. Multumesc
SwethaKandikonda-MT