Rendre des PDF contenant des images stockées dans Azure Blob Storage
Azure Blob Storage est un service de stockage en nuage fourni par Microsoft Azure. Il est conçu pour stocker de grandes quantités de données non structurées, telles que des données textuelles ou binaires, accessibles via HTTP ou HTTPS.
Certains développeurs souhaitent utiliser des images stockées dans Azure Blob Storage. Cela pose un problème car les données de l'image sont stockées sous forme binaire plutôt que sous forme de fichier, qui pourrait facilement être référencé par HTML. La solution consiste à convertir les images en chaîne base64 et à les ajouter à une balise img.
Commencez avec IronPDF
Commencez à utiliser IronPDF dans votre projet dès aujourd'hui avec un essai gratuit.
Comment rendre les images stockées dans Azure Blob Storage ?
- Télécharger IronPDF pour le rendu d'images stockées dans Azure Blob
- Gérer le processus de récupération du blob
- Utilisez la méthode ToBase64String pour convertir les octets en base64
- Inclure l'information base64 dans la balise img
- Transformation du HTML en PDF
Convertir Azure Blob en HTML
En supposant que vous avez déjà configuré un compte Azure Storage et que vous disposez d'un conteneur avec des blobs, vous devez également gérer l'authentification et la connexion à votre Azure Storage dans le projet C#. Ensuite, vous pouvez utiliser la méthode DownloadToStreamAsync
pour télécharger l'image en tant que flux. Les informations du flux peuvent ensuite être converties en Base64 et intégrées dans la balise img de HTML. Enfin, la variable imageTag peut être intégrée dans un document HTML.
// Define your connection string and container name
string connectionString = "your_connection_string";
string containerName = "your_container_name";
// Initialize BlobServiceClient with the connection string
BlobServiceClient blobServiceClient = new BlobServiceClient(connectionString);
// Get the BlobContainerClient for the specified container
BlobContainerClient blobContainer = blobServiceClient.GetBlobContainerClient(containerName);
// Get Blob
var blob = blobContainer.GetBlobReference("867.jpg");
var stream = new MemoryStream();
await blob.DownloadToStreamAsync(stream);
var array = new byte[blob.Properties.Length];
await blob.DownloadToByteArrayAsync(target: array, 0);
// Convert bytes to base64
var base64 = Convert.ToBase64String(array);
var imageTag = $"<img src=\"data:image/jpeg;base64, {base64}\"/><br/>";
// Define your connection string and container name
string connectionString = "your_connection_string";
string containerName = "your_container_name";
// Initialize BlobServiceClient with the connection string
BlobServiceClient blobServiceClient = new BlobServiceClient(connectionString);
// Get the BlobContainerClient for the specified container
BlobContainerClient blobContainer = blobServiceClient.GetBlobContainerClient(containerName);
// Get Blob
var blob = blobContainer.GetBlobReference("867.jpg");
var stream = new MemoryStream();
await blob.DownloadToStreamAsync(stream);
var array = new byte[blob.Properties.Length];
await blob.DownloadToByteArrayAsync(target: array, 0);
// Convert bytes to base64
var base64 = Convert.ToBase64String(array);
var imageTag = $"<img src=\"data:image/jpeg;base64, {base64}\"/><br/>";
' Define your connection string and container name
Dim connectionString As String = "your_connection_string"
Dim containerName As String = "your_container_name"
' Initialize BlobServiceClient with the connection string
Dim blobServiceClient As New BlobServiceClient(connectionString)
' Get the BlobContainerClient for the specified container
Dim blobContainer As BlobContainerClient = blobServiceClient.GetBlobContainerClient(containerName)
' Get Blob
Dim blob = blobContainer.GetBlobReference("867.jpg")
Dim stream = New MemoryStream()
Await blob.DownloadToStreamAsync(stream)
Dim array = New Byte(blob.Properties.Length - 1){}
Await blob.DownloadToByteArrayAsync(target:= array, 0)
' Convert bytes to base64
Dim base64 = Convert.ToBase64String(array)
Dim imageTag = $"<img src=""data:image/jpeg;base64, {base64}""/><br/>"
Convertir HTML en PDF
A partir de l'imageTag, il peut être converti en PDF en utilisant la méthode RenderHtmlAsPdf
de ChromePdfRenderer.
:path=/static-assets/pdf/content-code-examples/how-to/images-azure-blob-storage-html-to-pdf.cs
using IronPdf;
// Instantiate Renderer
var renderer = new ChromePdfRenderer();
// Create a PDF from a HTML string using C#
var pdf = renderer.RenderHtmlAsPdf(imageTag);
// Export to a file
pdf.SaveAs("imageToPdf.pdf");
Imports IronPdf
' Instantiate Renderer
Private renderer = New ChromePdfRenderer()
' Create a PDF from a HTML string using C#
Private pdf = renderer.RenderHtmlAsPdf(imageTag)
' Export to a file
pdf.SaveAs("imageToPdf.pdf")