Cómo convertir HTML a PDF en C# (Guía para desarrolladores)
La conversión de HTML a PDF en C# suele parecer sencilla hasta que aparecen los requisitos del mundo real. Los desarrolladores encuentran rápidamente limitaciones que afectan a la precisión de la representación, la implementación y la escalabilidad.
Más allá de la renderización, la compatibilidad con la infraestructura se convierte en un aspecto crítico. Los equipos deben asegurarse de que la generación de PDF funcione en tiempos de ejecución .NET modernos, plataformas en la nube y entornos en contenedores sin merma del rendimiento.
Para subsanar estas deficiencias, las soluciones modernas basadas en Chrome, como IronPDF, ofrecen una mayor fidelidad de representación, una compatibilidad más amplia con plataformas y flujos de trabajo de implementación listos para la producción, que se exploran paso a paso en el resto de esta guía.
TL;DR: Guía de inicio rápido para convertir HTML a PDF
You can easily convert HTML to PDF in C# using the IronPDF library, which provides the ChromePdfRenderer.RenderHtmlAsPdf method to create high-quality PDF files from HTML, CSS, and JavaScript.
-
Instala IronPDF con el Administrador de Paquetes NuGet
PM > Install-Package IronPdf -
Copie y ejecute este fragmento de código.
IronPdf.ChromePdfRenderer .StaticRenderHtmlAsPdf("<p>Hello World</p>") .SaveAs("pixelperfect.pdf"); -
Despliegue para probar en su entorno real
Comienza a usar IronPDF en tu proyecto hoy mismo con una prueba gratuita
Después de haber comprado o inscrito en una prueba de 30 días de IronPDF, busque la clave de licencia enviada a su correo electrónico. Establece la propiedad TempFolderPath de IronPdf.Installation.
IronPdf.License.LicenseKey = "KEY";
IronPdf.License.LicenseKey = "KEY";
Imports IronPdf
IronPdf.License.LicenseKey = "KEY"
¿Por qué los desarrolladores de .NET necesitan un convertidor de HTML a PDF para C#?
IronPDF aprovecha un motor de renderizado Google Chromium incorporado para asegurar conversiones de alta fidelidad, preservando con precisión el diseño y estilo de su contenido web.
✅ Motor de Renderizado de Chrome Robusto: El motor Blink de Chrome para una conversión precisa de HTML a PDF, ahora mejorado con correcciones para memoria, formularios y precisión de renderizado (v2025.9.4)
✅ Precisión de Pixel-Perfect: Los PDFs generados coinciden exactamente con la web, no una versión optimizada para impresión. Las correcciones recientes cubren recorte de encabezados y pies de página personalizados, preservación de texto en escala de grises y caracteres especiales/emojis en metadatos (a partir de v2025.9.4)
✅ Soporte Completo para la Web Moderna: Soporte completo para CSS3, HTML5, JavaScript para todos los elementos HTML. Las mejoras recientes cubren el manejo de campos de formulario para áreas de texto largas y casillas de verificación.
✅ Aumento de Rendimiento de 5-20 Veces: Mucho más rápido que la automatización del navegador o los controladores web, ahora con correcciones de fugas de memoria y reducciones de tamaños de archivo para elementos repetidos como sellos/encabezados en operaciones por lotes.
✅ Cumplimiento de PDF/UA: Generación de PDFs accesibles que cumplen con los estándares de la Sección 508, mejorado para renderización de formularios multiplataforma (por ejemplo, Linux).
✅ Sin Dependencias Externas: No hay ejecutables para instalar en los servidores
✅ Diseñado para C#, F# y VB.NET ejecutándose en .NET 10, 9, 8, 7, 6, Core, Standard, o Framework
IronPDF simplifica el proceso para desarrolladores .NET, ofreciendo una solución sencilla y eficiente para generar documentos PDF de aspecto profesional desde el HTML de su aplicación web. Desde facturas e informes hasta certificados y archivos, los desarrolladores pueden trabajar con su stack web familiar mientras IronPDF maneja lo complejo en solo unas líneas de código.
RELATED: IronPDF Changelog: Updates, milestones, roadmap
Lo que aprenderás
-
Cómo utilizar las funciones avanzadas de generación y seguridad de PDF
-
Compare IronPDF with Other .NET PDF Libraries
- Matriz de decisión rápida: IronPDF frente a otros conversores de PDF .NET
- Comparación detallada: IronPDF frente a otros conversores de PDF .NET
- Comparación de la conversión de HTML a PDF en la vida real: Rendering Reddit's Homepage
- Conclusión sobre el rendimiento y la calidad del PDF de salida
- Resumen
- Troubleshooting & Technical Support
1. How to Convert HTML to PDF C
Ya sea que trabaje con cadenas HTML, URLs o archivos HTML, IronPDF proporciona opciones flexibles para generar documentos PDF de alta calidad que cumplen con sus requisitos específicos.
En este tutorial, lo guiaremos por los escenarios más comunes, incluyendo cadena HTML a PDF, URL a PDF y archivo HTML a PDF. Además, IronPDF también proporciona una variedad de operaciones para manipular documentos PDF:
| Conversión versátil de PDF | Conversión de páginas web dinámicas a PDF |
|---|---|
|
Cómo convertir una cadena HTML a PDF
La operación más fundamental es convertir una cadena HTML a PDF. Este método es perfecto para contenido HTML generado dinámicamente. The RenderHtmlAsPdf method fully supports HTML5, CSS3, JavaScript, and images when you convert HTML to PDF directly.
var renderer = new ChromePdfRenderer();
// Create the Chrome renderer
var renderer = new ChromePdfRenderer();
// Convert HTML string to PDF
var pdf = renderer.RenderHtmlAsPdf("<h1>Hello IronPdf</h1>");
// Save the PDF
pdf.SaveAs("output.pdf");
var renderer = new ChromePdfRenderer();
// Create the Chrome renderer
var renderer = new ChromePdfRenderer();
// Convert HTML string to PDF
var pdf = renderer.RenderHtmlAsPdf("<h1>Hello IronPdf</h1>");
// Save the PDF
pdf.SaveAs("output.pdf");
Dim renderer As New ChromePdfRenderer()
' Create the Chrome renderer
Dim renderer As New ChromePdfRenderer()
' Convert HTML string to PDF
Dim pdf = renderer.RenderHtmlAsPdf("<h1>Hello IronPdf</h1>")
' Save the PDF
pdf.SaveAs("output.pdf")
When your HTML string references local assets like images or stylesheets, use the BaseUrlPath parameter to properly convert HTML content with all resources:
var renderer = new ChromePdfRenderer();
var renderer = new ChromePdfRenderer();
// Convert HTML content with local image and CSS references
string html = @"
<link rel='stylesheet' href='styles.css'>
<img src='logo.png' alt='Company Logo'>
<h1>Company Report</h1>
<p>Annual report content...</p>";
// Set base path for resolving relative URLs in HTML to PDF conversion
var pdf = renderer.RenderHtmlAsPdf(html, @"C:\MyProject\Assets\");
pdf.SaveAs("report.pdf");
var renderer = new ChromePdfRenderer();
var renderer = new ChromePdfRenderer();
// Convert HTML content with local image and CSS references
string html = @"
<link rel='stylesheet' href='styles.css'>
<img src='logo.png' alt='Company Logo'>
<h1>Company Report</h1>
<p>Annual report content...</p>";
// Set base path for resolving relative URLs in HTML to PDF conversion
var pdf = renderer.RenderHtmlAsPdf(html, @"C:\MyProject\Assets\");
pdf.SaveAs("report.pdf");
Imports IronPdf
Dim renderer As New ChromePdfRenderer()
' Convert HTML content with local image and CSS references
Dim html As String = "
<link rel='stylesheet' href='styles.css'>
<img src='logo.png' alt='Company Logo'>
<h1>Company Report</h1>
<p>Annual report content...</p>"
' Set base path for resolving relative URLs in HTML to PDF conversion
Dim pdf = renderer.RenderHtmlAsPdf(html, "C:\MyProject\Assets\")
pdf.SaveAs("report.pdf")
RELATED HOW-TO ARTICLE: How to Convert HTML String to PDF in C#
Cómo exportar una URL existente a PDF
Renderizar páginas web completas a PDFs con C# permite a los equipos separar el diseño del PDF y el trabajo de renderizado del back-end. Este enfoque le permite convertir cualquier URL específica directamente al formato PDF.
CSS de Impresión vs Pantalla
Puede configurar IronPDF para renderizar usando cualquier tipo de medios CSS.
var renderer = new ChromePdfRenderer();
using IronPdf.Rendering;
// Initialize HTML to PDF converter
var renderer = new ChromePdfRenderer();
// Configure CSS media type for rendering specified URLs
renderer.RenderingOptions.CssMediaType = PdfCssMediaType.Print;
// Screen media type shows the entire web page as displayed on screen
var renderer = new ChromePdfRenderer();
using IronPdf.Rendering;
// Initialize HTML to PDF converter
var renderer = new ChromePdfRenderer();
// Configure CSS media type for rendering specified URLs
renderer.RenderingOptions.CssMediaType = PdfCssMediaType.Print;
// Screen media type shows the entire web page as displayed on screen
Imports IronPdf.Rendering
' Initialize HTML to PDF converter
Dim renderer As New ChromePdfRenderer()
' Configure CSS media type for rendering specified URLs
renderer.RenderingOptions.CssMediaType = PdfCssMediaType.Print
' Screen media type shows the entire web page as displayed on screen
Soporte de JavaScript
IronPDF soporta completamente JavaScript, jQuery e incluso AJAX cuando convierte HTML a PDF. Para contenido HTML dinámico, puede configurar IronPDF para esperar la finalización del JavaScript antes de renderizar páginas web en PDF. Esto es perfecto para aplicaciones de una sola página y sitios web dinámicos.
var renderer = new ChromePdfRenderer();
// Configure JavaScript rendering for dynamic HTML content to PDF
var renderer = new ChromePdfRenderer();
// Enable JavaScript execution during PDF generation
renderer.RenderingOptions.EnableJavaScript = true;
// WaitFor.RenderDelay pauses before capturing the HTML
renderer.RenderingOptions.WaitFor.RenderDelay = 500; // milliseconds
var renderer = new ChromePdfRenderer();
// Configure JavaScript rendering for dynamic HTML content to PDF
var renderer = new ChromePdfRenderer();
// Enable JavaScript execution during PDF generation
renderer.RenderingOptions.EnableJavaScript = true;
// WaitFor.RenderDelay pauses before capturing the HTML
renderer.RenderingOptions.WaitFor.RenderDelay = 500; // milliseconds
Dim renderer As New ChromePdfRenderer()
' Configure JavaScript rendering for dynamic HTML content to PDF
Dim renderer As New ChromePdfRenderer()
' Enable JavaScript execution during PDF generation
renderer.RenderingOptions.EnableJavaScript = True
' WaitFor.RenderDelay pauses before capturing the HTML
renderer.RenderingOptions.WaitFor.RenderDelay = 500 ' milliseconds
La ejecución de JavaScript también se puede mostrar cuando se renderiza un gráfico de acordes d3.js avanzado desde una página web al formato PDF:
var renderer = new ChromePdfRenderer();
// Create renderer for JavaScript-heavy HTML
var renderer = new ChromePdfRenderer();
// Convert d3.js visualization web page to PDF
var pdf = renderer.RenderUrlAsPdf("https://bl.ocks.org/mbostock/4062006");
// Save the interactive chart as static PDF
pdf.SaveAs("chart.pdf");
var renderer = new ChromePdfRenderer();
// Create renderer for JavaScript-heavy HTML
var renderer = new ChromePdfRenderer();
// Convert d3.js visualization web page to PDF
var pdf = renderer.RenderUrlAsPdf("https://bl.ocks.org/mbostock/4062006");
// Save the interactive chart as static PDF
pdf.SaveAs("chart.pdf");
Dim renderer As New ChromePdfRenderer()
' Create renderer for JavaScript-heavy HTML
renderer = New ChromePdfRenderer()
' Convert d3.js visualization web page to PDF
Dim pdf = renderer.RenderUrlAsPdf("https://bl.ocks.org/mbostock/4062006")
' Save the interactive chart as static PDF
pdf.SaveAs("chart.pdf")
CSS Responsivo
As responsive web pages are designed to be viewed in a browser, and IronPDF does not open a real browser window in your server's OS, responsive HTML elements may render at their smallest size. PdfCssMediaType.Print is recommended to navigate this issue when rendering entire web pages.
// Configure for optimal responsive design handling in HTML to PDF
renderer.RenderingOptions.CssMediaType = IronPdf.Rendering.PdfCssMediaType.Print;
// Configure for optimal responsive design handling in HTML to PDF
renderer.RenderingOptions.CssMediaType = IronPdf.Rendering.PdfCssMediaType.Print;
```vbnet
' Configure for optimal responsive design handling in HTML to PDF
renderer.RenderingOptions.CssMediaType = IronPdf.Rendering.PdfCssMediaType.Print
```
RELATED HOW-TO ARTICLE: How to Render URL to PDF
Cómo convertir un archivo HTML a PDF
Convertir archivos HTML locales a PDF preserva todos los recursos relativos incluyendo CSS, imágenes y JavaScript, como si se abrieran usando el protocolo file://. Este método de HTML a PDF es mejor para convertir plantillas o páginas HTML pre-diseñadas a documentos PDF.
var renderer = new ChromePdfRenderer();
// Initialize ChromePdfRenderer for HTML file conversion
var renderer = new ChromePdfRenderer();
// Convert HTML file to PDF documents
// Preserves all relative paths and linked resources in HTML
var pdf = renderer.RenderHtmlFileAsPdf("Assets/TestInvoice1.html");
// Save the HTML file as PDF
pdf.SaveAs("Invoice.pdf");
// All CSS, JavaScript, and images load correctly in the generated PDF
var renderer = new ChromePdfRenderer();
// Initialize ChromePdfRenderer for HTML file conversion
var renderer = new ChromePdfRenderer();
// Convert HTML file to PDF documents
// Preserves all relative paths and linked resources in HTML
var pdf = renderer.RenderHtmlFileAsPdf("Assets/TestInvoice1.html");
// Save the HTML file as PDF
pdf.SaveAs("Invoice.pdf");
// All CSS, JavaScript, and images load correctly in the generated PDF
Dim renderer As New ChromePdfRenderer()
' Initialize ChromePdfRenderer for HTML file conversion
Dim renderer As New ChromePdfRenderer()
' Convert HTML file to PDF documents
' Preserves all relative paths and linked resources in HTML
Dim pdf = renderer.RenderHtmlFileAsPdf("Assets/TestInvoice1.html")
' Save the HTML file as PDF
pdf.SaveAs("Invoice.pdf")
' All CSS, JavaScript, and images load correctly in the generated PDF
RELATED HOW-TO Article: Render HTML File to PDF
How to Convert Razor Pages to PDF
If your ASP.NET Core project already uses Razor Pages, you can convert them directly to PDF without rebuilding your HTML. IronPDF's Razor extension adds the RenderRazorToPdf method, which takes your .cshtml page — complete with its model and layout — and renders it as a PDF document in a single call.
PM > Install-Package IronPdf.Extensions.Razor
PM > Install-Package IronPdf.Extensions.Razor
var renderer = new ChromePdfRenderer();
var renderer = new ChromePdfRenderer();
// Render a Razor Page directly to PDF
PdfDocument pdf = renderer.RenderRazorToPdf(this);
Response.Headers.Add("Content-Disposition", "inline");
return new FileContentResult(pdf.BinaryData, "application/pdf");
var renderer = new ChromePdfRenderer();
var renderer = new ChromePdfRenderer();
// Render a Razor Page directly to PDF
PdfDocument pdf = renderer.RenderRazorToPdf(this);
Response.Headers.Add("Content-Disposition", "inline");
return new FileContentResult(pdf.BinaryData, "application/pdf");
Imports System.IO
Imports Microsoft.AspNetCore.Mvc
Dim renderer As New ChromePdfRenderer()
' Render a Razor Page directly to PDF
Dim pdf As PdfDocument = renderer.RenderRazorToPdf(Me)
Response.Headers.Add("Content-Disposition", "inline")
Return New FileContentResult(pdf.BinaryData, "application/pdf")
RELATED HOW-TO Article: How to Convert CSHTML to PDF in Razor Pages
How to Convert MVC Views to PDF
Teams using the MVC pattern can generate PDFs straight from their existing Views and controllers. Install the MVC Core extension package, then call RenderRazorViewToPdf with your view path and model — IronPDF handles the Razor rendering pipeline and outputs a finished PDF.
This is especially useful for reports, invoices, and any page where the HTML is already designed and tested in the browser. The generated PDF preserves the full View output, including layout pages and partial views.
PM > Install-Package IronPdf.Extensions.Mvc.Core
PM > Install-Package IronPdf.Extensions.Mvc.Core
First, register the IRazorViewRenderer service in your Program.cs so your controllers can inject it:
using IronPdf.Extensions.Mvc.Core;
var builder = WebApplication.CreateBuilder(args);
builder.Services.AddControllersWithViews();
// Register the Razor view renderer for IronPDF
builder.Services.AddSingleton<IHttpContextAccessor, HttpContextAccessor>();
builder.Services.AddSingleton<IRazorViewRenderer, RazorViewRenderer>();
using IronPdf.Extensions.Mvc.Core;
var builder = WebApplication.CreateBuilder(args);
builder.Services.AddControllersWithViews();
// Register the Razor view renderer for IronPDF
builder.Services.AddSingleton<IHttpContextAccessor, HttpContextAccessor>();
builder.Services.AddSingleton<IRazorViewRenderer, RazorViewRenderer>();
Imports IronPdf.Extensions.Mvc.Core
Dim builder = WebApplication.CreateBuilder(args)
builder.Services.AddControllersWithViews()
' Register the Razor view renderer for IronPDF
builder.Services.AddSingleton(Of IHttpContextAccessor, HttpContextAccessor)()
builder.Services.AddSingleton(Of IRazorViewRenderer, RazorViewRenderer)()
Then in your controller action, inject the renderer and convert any View to PDF:
var renderer = new ChromePdfRenderer();
using IronPdf.Extensions.Mvc.Core;
var renderer = new ChromePdfRenderer();
// Render an MVC View with model data to PDF
PdfDocument pdf = renderer.RenderRazorViewToPdf(
_viewRenderService, "Views/Home/Report.cshtml", reportModel);
Response.Headers.Add("Content-Disposition", "inline");
return new FileContentResult(pdf.BinaryData, "application/pdf");
var renderer = new ChromePdfRenderer();
using IronPdf.Extensions.Mvc.Core;
var renderer = new ChromePdfRenderer();
// Render an MVC View with model data to PDF
PdfDocument pdf = renderer.RenderRazorViewToPdf(
_viewRenderService, "Views/Home/Report.cshtml", reportModel);
Response.Headers.Add("Content-Disposition", "inline");
return new FileContentResult(pdf.BinaryData, "application/pdf");
Imports IronPdf.Extensions.Mvc.Core
Dim renderer As New ChromePdfRenderer()
' Render an MVC View with model data to PDF
Dim pdf As PdfDocument = renderer.RenderRazorViewToPdf(_viewRenderService, "Views/Home/Report.cshtml", reportModel)
Response.Headers.Add("Content-Disposition", "inline")
Return New FileContentResult(pdf.BinaryData, "application/pdf")
RELATED HOW-TO Article: How to Convert Views to PDF in ASP.NET Core MVC
2. Cómo configurar los ajustes de HTML a PDF
In terms of manipulating PDF documents, IronPDF provides extensive customizations through the ChromePdfRenderer.RenderingOptions property for rendered PDFs.
| Configuración | Descripción | Ejemplo |
|---|---|---|
| Tamaño de papel | Establecer las dimensiones de página para archivos PDF existentes (A4, Carta, Legal, etc.) | `PdfPaperSize.A4` |
| Orientación del papel | Establecer vertical u horizontal para archivos PDF existentes | `PdfPaperOrientation.Landscape` |
| Margen superior/inferior/izquierdo/derecho | Establecer márgenes de página en milímetros (predeterminado: 25 mm) | |
| Tipo de medio CSS | CSS de pantalla o impresión para HTML a PDF | `PdfCssMediaType.Print` |
| Fondos de impresión HTML | Incluir colores/imágenes de fondo (predeterminado: verdadero) | verdadero |
| Habilitar JavaScript | Ejecutar JavaScript antes de renderizar el contenido HTML | verdadero |
| Esperar.Retraso de renderizado | Tiempo de espera para contenido HTML dinámico (ms) | 500 |
Vea este fragmento de código para un ejemplo completo de configuración para manipular documentos PDF:
var renderer = new ChromePdfRenderer();
using IronPdf.Rendering;
var renderer = new ChromePdfRenderer();
// Apply print-specific CSS rules
renderer.RenderingOptions.CssMediaType = PdfCssMediaType.Print;
// Set custom margins in millimeters
renderer.RenderingOptions.MarginTop = 50;
renderer.RenderingOptions.MarginBottom = 50;
// Enable background colors and images
renderer.RenderingOptions.PrintHtmlBackgrounds = true;
// Set paper size and orientation
renderer.RenderingOptions.PaperSize = PdfPaperSize.A4;
renderer.RenderingOptions.PaperOrientation = PdfPaperOrientation.Landscape;
// Generate PDFs with all settings applied to HTML content
var htmlContent = "<div style='background-color: #f0f0f0; padding: 20px;'><h1>Styled Content</h1></div>";
var pdfDocument = renderer.RenderHtmlAsPdf(htmlContent);
pdfDocument.SaveAs("styled-output.pdf");
var renderer = new ChromePdfRenderer();
using IronPdf.Rendering;
var renderer = new ChromePdfRenderer();
// Apply print-specific CSS rules
renderer.RenderingOptions.CssMediaType = PdfCssMediaType.Print;
// Set custom margins in millimeters
renderer.RenderingOptions.MarginTop = 50;
renderer.RenderingOptions.MarginBottom = 50;
// Enable background colors and images
renderer.RenderingOptions.PrintHtmlBackgrounds = true;
// Set paper size and orientation
renderer.RenderingOptions.PaperSize = PdfPaperSize.A4;
renderer.RenderingOptions.PaperOrientation = PdfPaperOrientation.Landscape;
// Generate PDFs with all settings applied to HTML content
var htmlContent = "<div style='background-color: #f0f0f0; padding: 20px;'><h1>Styled Content</h1></div>";
var pdfDocument = renderer.RenderHtmlAsPdf(htmlContent);
pdfDocument.SaveAs("styled-output.pdf");
Imports IronPdf.Rendering
Dim renderer As New ChromePdfRenderer()
' Apply print-specific CSS rules
renderer.RenderingOptions.CssMediaType = PdfCssMediaType.Print
' Set custom margins in millimeters
renderer.RenderingOptions.MarginTop = 50
renderer.RenderingOptions.MarginBottom = 50
' Enable background colors and images
renderer.RenderingOptions.PrintHtmlBackgrounds = True
' Set paper size and orientation
renderer.RenderingOptions.PaperSize = PdfPaperSize.A4
renderer.RenderingOptions.PaperOrientation = PdfPaperOrientation.Landscape
' Generate PDFs with all settings applied to HTML content
Dim htmlContent As String = "<div style='background-color: #f0f0f0; padding: 20px;'><h1>Styled Content</h1></div>"
Dim pdfDocument = renderer.RenderHtmlAsPdf(htmlContent)
pdfDocument.SaveAs("styled-output.pdf")
ARTÍCULOS RELACIONADOS:
| Conversión de PDF a medida | Perfeccionar Diseño PDF |
|---|---|
How to Set Custom HTTP Headers, Cookies, and Login Credentials
When rendering URLs that require authentication or specific request metadata, IronPDF allows you to include login credentials, session cookies, and HTTP headers with the request. This enables rendering of intranet dashboards, restricted reports, or API-generated pages directly to PDF without needing to retrieve the HTML separately.
For basic or NTLM authentication, set a LoginCredentials object on the renderer. For token-based or session-based access, pass cookies and headers through RenderingOptions before calling RenderUrlAsPdf.
var renderer = new ChromePdfRenderer();
var renderer = new ChromePdfRenderer();
// Network authentication (Basic, Digest, NTLM)
renderer.LoginCredentials = new ChromeHttpLoginCredentials
{
NetworkUsername = "user@domain.com",
NetworkPassword = "securePassword"
};
// Session cookies for authenticated pages
renderer.RenderingOptions.CustomCookies["sessionId"] = "abc123";
// Custom HTTP headers (e.g., Bearer tokens, API keys)
renderer.RenderingOptions.CustomHttpRequestHeaders["Authorization"] = "Bearer eyJhbGciOi...";
var pdf = renderer.RenderUrlAsPdf("https://intranet.company.com/quarterly-report");
pdf.SaveAs("quarterly-report.pdf");
var renderer = new ChromePdfRenderer();
var renderer = new ChromePdfRenderer();
// Network authentication (Basic, Digest, NTLM)
renderer.LoginCredentials = new ChromeHttpLoginCredentials
{
NetworkUsername = "user@domain.com",
NetworkPassword = "securePassword"
};
// Session cookies for authenticated pages
renderer.RenderingOptions.CustomCookies["sessionId"] = "abc123";
// Custom HTTP headers (e.g., Bearer tokens, API keys)
renderer.RenderingOptions.CustomHttpRequestHeaders["Authorization"] = "Bearer eyJhbGciOi...";
var pdf = renderer.RenderUrlAsPdf("https://intranet.company.com/quarterly-report");
pdf.SaveAs("quarterly-report.pdf");
Imports IronPdf
Dim renderer As New ChromePdfRenderer()
' Network authentication (Basic, Digest, NTLM)
renderer.LoginCredentials = New ChromeHttpLoginCredentials With {
.NetworkUsername = "user@domain.com",
.NetworkPassword = "securePassword"
}
' Session cookies for authenticated pages
renderer.RenderingOptions.CustomCookies("sessionId") = "abc123"
' Custom HTTP headers (e.g., Bearer tokens, API keys)
renderer.RenderingOptions.CustomHttpRequestHeaders("Authorization") = "Bearer eyJhbGciOi..."
Dim pdf = renderer.RenderUrlAsPdf("https://intranet.company.com/quarterly-report")
pdf.SaveAs("quarterly-report.pdf")
ARTÍCULOS RELACIONADOS: Render PDFs Behind Login Authentication | Custom HTTP Request Headers
How to Configure Proxy for PDF Rendering
When rendering HTML that loads external resources behind a corporate proxy, pass the proxy address as the third parameter on RenderHtmlAsPdf(). This is a method parameter, not a property on ChromePdfRenderOptions — so it's set per render call, not on the renderer instance.
For authenticated proxies, embed credentials directly in the URL using http://user:pass@host:port format. URL-encode special characters in passwords with Uri.EscapeDataString().
var renderer = new ChromePdfRenderer();
var renderer = new ChromePdfRenderer();
// Proxy is the third parameter — not a render option
PdfDocument pdf = renderer.RenderHtmlAsPdf(
"<h1>Report</h1><link rel='stylesheet' href='https://cdn.example.com/styles.css'>",
baseUrlOrPath: null,
proxy: "http://proxy.corp.local:8080"
);
pdf.SaveAs("proxied-report.pdf");
var renderer = new ChromePdfRenderer();
var renderer = new ChromePdfRenderer();
// Proxy is the third parameter — not a render option
PdfDocument pdf = renderer.RenderHtmlAsPdf(
"<h1>Report</h1><link rel='stylesheet' href='https://cdn.example.com/styles.css'>",
baseUrlOrPath: null,
proxy: "http://proxy.corp.local:8080"
);
pdf.SaveAs("proxied-report.pdf");
Dim renderer As New ChromePdfRenderer()
' Proxy is the third parameter — not a render option
Dim pdf As PdfDocument = renderer.RenderHtmlAsPdf(
"<h1>Report</h1><link rel='stylesheet' href='https://cdn.example.com/styles.css'>",
baseUrlOrPath:=Nothing,
proxy:="http://proxy.corp.local:8080"
)
pdf.SaveAs("proxied-report.pdf")
Note that RenderUrlAsPdf() does not accept a proxy parameter. To render a live URL behind a proxy, fetch the HTML first with HttpClient configured with a WebProxy, then pass it to RenderHtmlAsPdf() with the proxy parameter for asset loading.
RELATED HOW-TO Article: How to Configure Proxy Servers for PDF Rendering
3. Cómo utilizar las funciones avanzadas de generación y seguridad de PDF
Desbloquee capacidades a nivel empresarial para la conversión de HTML a PDF con plantillas avanzadas, operaciones asíncronas y características de seguridad. Estos métodos de manipulación de PDF le permiten crear documentos PDF a gran escala, proteger archivos PDF sensibles y asegurar la autenticidad de los documentos cuando convierte HTML a un formato PDF profesional.
Cómo generar una plantilla HTML para la creación de PDF por lotes
Creación Básica de PDF en Lote
La creación de PDF en lote es esencial para generar múltiples documentos PDF personalizados de manera eficiente. For basic scenarios, the String.Format method in C# works best for simple PDF manipulation.
// Simple HTML templating with String.Format
string htmlTemplate = String.Format("<h1>Hello {0}!</h1>", "World");
// Results in HTML content: <h1>Hello World!</h1>
// Simple HTML templating with String.Format
string htmlTemplate = String.Format("<h1>Hello {0}!</h1>", "World");
// Results in HTML content: <h1>Hello World!</h1>
' Simple HTML templating with String.Format
Dim htmlTemplate As String = String.Format("<h1>Hello {0}!</h1>", "World")
' Results in HTML content: <h1>Hello World!</h1>
Para plantillas más largas cuando necesita generar documentos PDF, use la sustitución de marcadores de posición en su contenido HTML: var renderer = new ChromePdfRenderer();
// Define reusable HTML template for PDF files
var htmlTemplate = "<p>Dear [[NAME]],</p><p>Thank you for your order.</p>";
// Customer names for batch PDF conversion processing
var names = new[] { "John", "James", "Jenny" };
// Create personalized PDF documents for each customer
var renderer = new ChromePdfRenderer();
foreach (var name in names)
{
// Replace placeholder with actual data in HTML string
var htmlInstance = htmlTemplate.Replace("[[NAME]]", name);
// Generate personalized PDF document from HTML content
var pdf = renderer.RenderHtmlAsPdf(htmlInstance);
// Save with customer-specific filename as PDF files
pdf.SaveAs($"{name}-invoice.pdf");
}
// Define reusable HTML template for PDF files
var htmlTemplate = "<p>Dear [[NAME]],</p><p>Thank you for your order.</p>";
// Customer names for batch PDF conversion processing
var names = new[] { "John", "James", "Jenny" };
// Create personalized PDF documents for each customer
var renderer = new ChromePdfRenderer();
foreach (var name in names)
{
// Replace placeholder with actual data in HTML string
var htmlInstance = htmlTemplate.Replace("[[NAME]]", name);
// Generate personalized PDF document from HTML content
var pdf = renderer.RenderHtmlAsPdf(htmlInstance);
// Save with customer-specific filename as PDF files
pdf.SaveAs($"{name}-invoice.pdf");
}
' Define reusable HTML template for PDF files
Dim htmlTemplate As String = "<p>Dear [[NAME]],</p><p>Thank you for your order.</p>"
' Customer names for batch PDF conversion processing
Dim names As String() = {"John", "James", "Jenny"}
' Create personalized PDF documents for each customer
Dim renderer As New ChromePdfRenderer()
For Each name In names
' Replace placeholder with actual data in HTML string
Dim htmlInstance As String = htmlTemplate.Replace("[[NAME]]", name)
' Generate personalized PDF document from HTML content
Dim pdf = renderer.RenderHtmlAsPdf(htmlInstance)
' Save with customer-specific filename as PDF files
pdf.SaveAs($"{name}-invoice.pdf")
Next
Plantillas de HTML a PDF con Handlebars.NET
For complex templates with loops and conditionals when you convert HTML to PDF, use advanced templating with Handlebars.NET to generate PDF documents with dynamic HTML content.
# First, install Handlebars.NET for HTML to PDF templating
PM > Install-Package Handlebars.NET
# First, install Handlebars.NET for HTML to PDF templating
PM > Install-Package Handlebars.NET
using HandlebarsDotNet;
var renderer = new ChromePdfRenderer();
// Define Handlebars template with placeholders for HTML content
var source =
@"<div class=""entry"">
<h1>{{title}}</h1>
<div class=""body"">
{{body}}
</div>
</div>";
// Compile template for reuse in PDF conversion
var template = Handlebars.Compile(source);
// Create data object (can be database records) for HTML to PDF directly
var data = new {
title = "Monthly Report",
body = "Sales increased by 15% this month."
};
// Merge template with data to create HTML content
var htmlResult = template(data);
// Convert templated HTML to PDF using the PDF converter
var renderer = new ChromePdfRenderer();
var pdf = renderer.RenderHtmlAsPdf(htmlResult);
pdf.SaveAs("monthly-report.pdf");
using HandlebarsDotNet;
var renderer = new ChromePdfRenderer();
// Define Handlebars template with placeholders for HTML content
var source =
@"<div class=""entry"">
<h1>{{title}}</h1>
<div class=""body"">
{{body}}
</div>
</div>";
// Compile template for reuse in PDF conversion
var template = Handlebars.Compile(source);
// Create data object (can be database records) for HTML to PDF directly
var data = new {
title = "Monthly Report",
body = "Sales increased by 15% this month."
};
// Merge template with data to create HTML content
var htmlResult = template(data);
// Convert templated HTML to PDF using the PDF converter
var renderer = new ChromePdfRenderer();
var pdf = renderer.RenderHtmlAsPdf(htmlResult);
pdf.SaveAs("monthly-report.pdf");
Imports HandlebarsDotNet
Dim renderer As New ChromePdfRenderer()
' Define Handlebars template with placeholders for HTML content
Dim source As String =
"<div class=""entry"">
<h1>{{title}}</h1>
<div class=""body"">
{{body}}
</div>
</div>"
' Compile template for reuse in PDF conversion
Dim template = Handlebars.Compile(source)
' Create data object (can be database records) for HTML to PDF directly
Dim data = New With {
.title = "Monthly Report",
.body = "Sales increased by 15% this month."
}
' Merge template with data to create HTML content
Dim htmlResult = template(data)
' Convert templated HTML to PDF using the PDF converter
Dim pdf = renderer.RenderHtmlAsPdf(htmlResult)
pdf.SaveAs("monthly-report.pdf")
RELATED HOW-TO ARTICLE: Learn more about Handlebars.NET on GitHub
Controlar saltos de página en PDF:
Gestionar la paginación en los documentos PDF generados garantiza diseños profesionales y legibles al convertir fragmentos de HTML. Usa CSS para controlar dónde se dividen las páginas en tus archivos PDF.<!DOCTYPE html>
<html>
<head>
<style type="text/css" media="print">
.page {
page-break-after: always;
page-break-inside: avoid;
}
</style>
</head>
<body>
<div class="page">
<h1>Page 1 Content</h1>
</div>
<div class="page">
<h1>Page 2 Content</h1>
</div>
<div class="page">
<h1>Page 3 Content</h1>
</div>
</body>
</html>
<!DOCTYPE html>
<html>
<head>
<style type="text/css" media="print">
.page {
page-break-after: always;
page-break-inside: avoid;
}
</style>
</head>
<body>
<div class="page">
<h1>Page 1 Content</h1>
</div>
<div class="page">
<h1>Page 2 Content</h1>
</div>
<div class="page">
<h1>Page 3 Content</h1>
</div>
</body>
</html>
Cómo generar un PDF mediante el método asíncrono
IronPDF ofrece rendimiento a nivel empresarial con soporte completo para async y multihilos para sus requisitos de conversión de HTML a PDF cuando necesita generar archivos PDF a gran escala.
var renderer = new ChromePdfRenderer();
using System.Threading.Tasks;
// Async method for non-blocking PDF generation from HTML content
public async Task<byte[]> GeneratePdfAsync(string html)
{
var renderer = new ChromePdfRenderer();
// Async HTML to PDF conversion preserves thread pool
var pdf = await renderer.RenderHtmlAsPdfAsync(html);
// Return PDF files as byte array for web responses
return pdf.BinaryData;
}
// Concurrent batch PDF generation for multiple HTML strings
public async Task GenerateMultiplePdfsAsync(List<string> htmlPlantillas)
{
var renderer = new ChromePdfRenderer();
// Create parallel conversion tasks to generate PDF documents
var tasks = htmlPlantillas.Select(html =>
renderer.RenderHtmlAsPdfAsync(html)
);
// Await all PDF conversions simultaneously
var pdfs = await Task.WhenAll(tasks);
// Save generated PDF files from HTML content
for (int i = 0; i < pdfs.Length; i++)
{
pdfs[i].SaveAs($"document-{i}.pdf");
}
}
var renderer = new ChromePdfRenderer();
using System.Threading.Tasks;
// Async method for non-blocking PDF generation from HTML content
public async Task<byte[]> GeneratePdfAsync(string html)
{
var renderer = new ChromePdfRenderer();
// Async HTML to PDF conversion preserves thread pool
var pdf = await renderer.RenderHtmlAsPdfAsync(html);
// Return PDF files as byte array for web responses
return pdf.BinaryData;
}
// Concurrent batch PDF generation for multiple HTML strings
public async Task GenerateMultiplePdfsAsync(List<string> htmlPlantillas)
{
var renderer = new ChromePdfRenderer();
// Create parallel conversion tasks to generate PDF documents
var tasks = htmlPlantillas.Select(html =>
renderer.RenderHtmlAsPdfAsync(html)
);
// Await all PDF conversions simultaneously
var pdfs = await Task.WhenAll(tasks);
// Save generated PDF files from HTML content
for (int i = 0; i < pdfs.Length; i++)
{
pdfs[i].SaveAs($"document-{i}.pdf");
}
}
Imports System.Threading.Tasks
' Async method for non-blocking PDF generation from HTML content
Public Async Function GeneratePdfAsync(html As String) As Task(Of Byte())
Dim renderer As New ChromePdfRenderer()
' Async HTML to PDF conversion preserves thread pool
Dim pdf = Await renderer.RenderHtmlAsPdfAsync(html)
' Return PDF files as byte array for web responses
Return pdf.BinaryData
End Function
' Concurrent batch PDF generation for multiple HTML strings
Public Async Function GenerateMultiplePdfsAsync(htmlPlantillas As List(Of String)) As Task
Dim renderer As New ChromePdfRenderer()
' Create parallel conversion tasks to generate PDF documents
Dim tasks = htmlPlantillas.Select(Function(html) renderer.RenderHtmlAsPdfAsync(html))
' Await all PDF conversions simultaneously
Dim pdfs = Await Task.WhenAll(tasks)
' Save generated PDF files from HTML content
For i As Integer = 0 To pdfs.Length - 1
pdfs(i).SaveAs($"document-{i}.pdf")
Next
End Function
- Use sistemas de 64 bits para un rendimiento óptimo de generación de PDF.
- Asegúrese de contar con recursos de servidor adecuados cuando genere documentos PDF (evite niveles gratuitos con poca capacidad)
- Permita RenderDelay suficiente for JavaScript complejo en contenido HTML.
- Reuse
ChromePdfRendererinstances when possible. - Aproveche correcciones de memoria de v2025.9.4 para operaciones por lotes/async y reducir recursos. pruebe con tamaños de archivo reducidos con encabezados/pies de página personalizados repetidos.
RELATED HOW-TO Article: How to Generate PDFs with Async and Multithreading
Cómo agregar funciones de seguridad avanzadas
Cómo Agregar Protección por Contraseña para Archivos PDF en .NET
Proteja documentos PDF generados sensibles con contraseñas y permisos cuando convierta contenido HTML a un formato PDF protegido.
var renderer = new ChromePdfRenderer();
var renderer = new ChromePdfRenderer();
// Convert HTML to PDF with security
var pdf = renderer.RenderHtmlAsPdf("<h1>Confidential Report</h1>");
// Configure security settings for PDF files
pdf.SecuritySettings.UserPassword = "user123"; // Password to open PDF documents
pdf.SecuritySettings.OwnerPassword = "owner456"; // Password to modify PDF files
// Set granular permissions for PDF format
pdf.SecuritySettings.AllowUserCopyPasteContent = false;
pdf.SecuritySettings.AllowUserAnnotations = false;
pdf.SecuritySettings.AllowUserPrinting = PrintPermissions.LowQualityPrint;
// Apply strong encryption to PDF documents
pdf.SecuritySettings.EncryptionAlgorithm = PdfEncryptionAlgorithm.AES256;
pdf.SaveAs("secure-document.pdf");
var renderer = new ChromePdfRenderer();
var renderer = new ChromePdfRenderer();
// Convert HTML to PDF with security
var pdf = renderer.RenderHtmlAsPdf("<h1>Confidential Report</h1>");
// Configure security settings for PDF files
pdf.SecuritySettings.UserPassword = "user123"; // Password to open PDF documents
pdf.SecuritySettings.OwnerPassword = "owner456"; // Password to modify PDF files
// Set granular permissions for PDF format
pdf.SecuritySettings.AllowUserCopyPasteContent = false;
pdf.SecuritySettings.AllowUserAnnotations = false;
pdf.SecuritySettings.AllowUserPrinting = PrintPermissions.LowQualityPrint;
// Apply strong encryption to PDF documents
pdf.SecuritySettings.EncryptionAlgorithm = PdfEncryptionAlgorithm.AES256;
pdf.SaveAs("secure-document.pdf");
Dim renderer As New ChromePdfRenderer()
Dim pdf = renderer.RenderHtmlAsPdf("<h1>Confidential Report</h1>")
' Configure security settings for PDF files
pdf.SecuritySettings.UserPassword = "user123" ' Password to open PDF documents
pdf.SecuritySettings.OwnerPassword = "owner456" ' Password to modify PDF files
' Set granular permissions for PDF format
pdf.SecuritySettings.AllowUserCopyPasteContent = False
pdf.SecuritySettings.AllowUserAnnotations = False
pdf.SecuritySettings.AllowUserPrinting = PrintPermissions.LowQualityPrint
' Apply strong encryption to PDF documents
pdf.SecuritySettings.EncryptionAlgorithm = PdfEncryptionAlgorithm.AES256
pdf.SaveAs("secure-document.pdf")
Cómo Agregar Firmas Digitales a Archivos PDF
Agregue firmas criptográficas para asegurar la autenticidad del documento PDF cuando genere archivos PDF a partir de contenido HTML.
var renderer = new ChromePdfRenderer();
using IronPdf.Signing;
var renderer = new ChromePdfRenderer();
// Generate PDF from HTML page
var pdf = renderer.RenderHtmlAsPdf("<h1>Contract Agreement</h1>");
// Create digital signature with certificate for PDF files
var signature = new PdfSignature("certificate.pfx", "password")
{
SigningContact = "legal@company.com",
SigningLocation = "New York, NY",
SigningReason = "Contract Approval",
SignerName = "Authorized Signer" // New property in v2025.8.8 for enhanced signature details
};
// Apply signature to PDF documents
pdf.Sign(signature);
pdf.SaveAs("signed-contract.pdf");
var renderer = new ChromePdfRenderer();
using IronPdf.Signing;
var renderer = new ChromePdfRenderer();
// Generate PDF from HTML page
var pdf = renderer.RenderHtmlAsPdf("<h1>Contract Agreement</h1>");
// Create digital signature with certificate for PDF files
var signature = new PdfSignature("certificate.pfx", "password")
{
SigningContact = "legal@company.com",
SigningLocation = "New York, NY",
SigningReason = "Contract Approval",
SignerName = "Authorized Signer" // New property in v2025.8.8 for enhanced signature details
};
// Apply signature to PDF documents
pdf.Sign(signature);
pdf.SaveAs("signed-contract.pdf");
Imports IronPdf.Signing
Dim renderer = New ChromePdfRenderer()
' Generate PDF from HTML page
Dim pdf = renderer.RenderHtmlAsPdf("<h1>Contract Agreement</h1>")
' Create digital signature with certificate for PDF files
Dim signature = New PdfSignature("certificate.pfx", "password") With {
.SigningContact = "legal@company.com",
.SigningLocation = "New York, NY",
.SigningReason = "Contract Approval",
.SignerName = "Authorized Signer" ' New property in v2025.8.8 for enhanced signature details
}
' Apply signature to PDF documents
pdf.Sign(signature)
pdf.SaveAs("signed-contract.pdf")
RELATED HOW-TO Article: Digitally Signing PDF Documents with C#
How to Convert HTML Forms to Fillable PDFs
To convert standard HTML form elements into interactive, fillable PDF form fields, enable the CreatePdfFormsFromHtml rendering option. This preserves text inputs, checkboxes, radio buttons, and dropdown menus as editable fields in the generated PDF document.
var renderer = new ChromePdfRenderer();
var renderer = new ChromePdfRenderer();
// Enable HTML form to PDF form conversion
renderer.RenderingOptions.CreatePdfFormsFromHtml = true;
string htmlForm = @"
<h2>Employee Onboarding Form</h2>
<form>
<label>Full Name:</label>
<input type='text' name='fullName' value='' /><br/>
<label>Department:</label>
<select name='department'>
<option value='engineering'>Engineering</option>
<option value='marketing'>Marketing</option>
<option value='sales'>Sales</option>
</select><br/>
<label>Agree to Terms:</label>
<input type='checkbox' name='agreeTerms' />
</form>";
var pdf = renderer.RenderHtmlAsPdf(htmlForm);
pdf.SaveAs("onboarding-form.pdf");
var renderer = new ChromePdfRenderer();
var renderer = new ChromePdfRenderer();
// Enable HTML form to PDF form conversion
renderer.RenderingOptions.CreatePdfFormsFromHtml = true;
string htmlForm = @"
<h2>Employee Onboarding Form</h2>
<form>
<label>Full Name:</label>
<input type='text' name='fullName' value='' /><br/>
<label>Department:</label>
<select name='department'>
<option value='engineering'>Engineering</option>
<option value='marketing'>Marketing</option>
<option value='sales'>Sales</option>
</select><br/>
<label>Agree to Terms:</label>
<input type='checkbox' name='agreeTerms' />
</form>";
var pdf = renderer.RenderHtmlAsPdf(htmlForm);
pdf.SaveAs("onboarding-form.pdf");
Dim renderer As New ChromePdfRenderer()
' Enable HTML form to PDF form conversion
renderer.RenderingOptions.CreatePdfFormsFromHtml = True
Dim htmlForm As String = "
<h2>Employee Onboarding Form</h2>
<form>
<label>Full Name:</label>
<input type='text' name='fullName' value='' /><br/>
<label>Department:</label>
<select name='department'>
<option value='engineering'>Engineering</option>
<option value='marketing'>Marketing</option>
<option value='sales'>Sales</option>
</select><br/>
<label>Agree to Terms:</label>
<input type='checkbox' name='agreeTerms' />
</form>"
Dim pdf = renderer.RenderHtmlAsPdf(htmlForm)
pdf.SaveAs("onboarding-form.pdf")
name attribute. Duplicate names will cause fields to share the same value in the generated PDF, leading to unexpected behavior when users fill out the form.RELATED HOW-TO Article: How to Create Fillable PDF Forms in C#
How to Convert Specific HTML Elements to PDF
To render a specific section of a page rather than the full document, isolate the target element before rendering. The most direct approach uses the JavaScript rendering option to replace the document body with the target element's content, combined with WaitFor.HtmlQuerySelector() to ensure the element exists before extraction. The snippet below preserves document.head so stylesheets and fonts carry over — without that step, CSS rules relying on ancestor selectors would be lost in the extracted PDF.
For server-side scenarios where you have access to the raw HTML, extract the target fragment with a parser like AngleSharp and pass it to RenderHtmlAsPdf() — no JavaScript execution needed.
var renderer = new ChromePdfRenderer();
var renderer = new ChromePdfRenderer();
renderer.RenderingOptions.EnableJavaScript = true;
// Replace the body with only the target element
renderer.RenderingOptions.JavaScript = @"
var el = document.querySelector('#invoice-summary');
if (el) {
var head = document.head.innerHTML;
document.body.innerHTML = el.outerHTML;
document.head.innerHTML = head;
}
";
// Wait for the target element before JS executes
renderer.RenderingOptions.WaitFor.HtmlQuerySelector("#invoice-summary", 10000);
var pdf = renderer.RenderHtmlAsPdf(fullPageHtml);
pdf.SaveAs("invoice-summary.pdf");
var renderer = new ChromePdfRenderer();
var renderer = new ChromePdfRenderer();
renderer.RenderingOptions.EnableJavaScript = true;
// Replace the body with only the target element
renderer.RenderingOptions.JavaScript = @"
var el = document.querySelector('#invoice-summary');
if (el) {
var head = document.head.innerHTML;
document.body.innerHTML = el.outerHTML;
document.head.innerHTML = head;
}
";
// Wait for the target element before JS executes
renderer.RenderingOptions.WaitFor.HtmlQuerySelector("#invoice-summary", 10000);
var pdf = renderer.RenderHtmlAsPdf(fullPageHtml);
pdf.SaveAs("invoice-summary.pdf");
Imports IronPdf
Dim renderer As New ChromePdfRenderer()
renderer.RenderingOptions.EnableJavaScript = True
' Replace the body with only the target element
renderer.RenderingOptions.JavaScript = "
var el = document.querySelector('#invoice-summary');
if (el) {
var head = document.head.innerHTML;
document.body.innerHTML = el.outerHTML;
document.head.innerHTML = head;
}
"
' Wait for the target element before JS executes
renderer.RenderingOptions.WaitFor.HtmlQuerySelector("#invoice-summary", 10000)
Dim pdf = renderer.RenderHtmlAsPdf(fullPageHtml)
pdf.SaveAs("invoice-summary.pdf")
RELATED HOW-TO Article: How to Convert HTML Elements and Partial Pages to PDF
How to Render Authenticated Pages to PDF
There are three mechanisms for rendering pages that sit behind authentication: network login credentials, custom cookies, and HTTP request headers. These cover the most common authentication scenarios when converting protected web content to PDF.
Login Credentials
Use ChromeHttpLoginCredentials for basic, digest, or NTLM authentication when converting protected URLs to PDF.
var renderer = new ChromePdfRenderer();
var renderer = new ChromePdfRenderer();
// Configure network authentication
renderer.LoginCredentials = new ChromeHttpLoginCredentials
{
NetworkUsername = "user@domain.com",
NetworkPassword = "securePassword",
AuthenticationType = ChromeHttpLoginCredentials.AuthType.Basic
};
var pdf = renderer.RenderUrlAsPdf("https://intranet.company.com/reports");
pdf.SaveAs("authenticated-report.pdf");
var renderer = new ChromePdfRenderer();
var renderer = new ChromePdfRenderer();
// Configure network authentication
renderer.LoginCredentials = new ChromeHttpLoginCredentials
{
NetworkUsername = "user@domain.com",
NetworkPassword = "securePassword",
AuthenticationType = ChromeHttpLoginCredentials.AuthType.Basic
};
var pdf = renderer.RenderUrlAsPdf("https://intranet.company.com/reports");
pdf.SaveAs("authenticated-report.pdf");
Imports System
Dim renderer As New ChromePdfRenderer()
' Configure network authentication
renderer.LoginCredentials = New ChromeHttpLoginCredentials With {
.NetworkUsername = "user@domain.com",
.NetworkPassword = "securePassword",
.AuthenticationType = ChromeHttpLoginCredentials.AuthType.Basic
}
Dim pdf = renderer.RenderUrlAsPdf("https://intranet.company.com/reports")
pdf.SaveAs("authenticated-report.pdf")
Cookies and HTTP Headers
For token-based or session-based authentication, attach custom cookies and HTTP headers directly to the rendering request.
var renderer = new ChromePdfRenderer();
var renderer = new ChromePdfRenderer();
// Add session cookies
renderer.RenderingOptions.CustomCookies["sessionId"] = "abc123token";
renderer.RenderingOptions.CustomCookies["authToken"] = "bearer-xyz";
// Add custom HTTP headers (e.g., API key or Bearer token)
renderer.RenderingOptions.CustomHttpRequestHeaders["Authorization"] = "Bearer eyJhbGciOi...";
var pdf = renderer.RenderUrlAsPdf("https://app.example.com/dashboard");
pdf.SaveAs("dashboard.pdf");
var renderer = new ChromePdfRenderer();
var renderer = new ChromePdfRenderer();
// Add session cookies
renderer.RenderingOptions.CustomCookies["sessionId"] = "abc123token";
renderer.RenderingOptions.CustomCookies["authToken"] = "bearer-xyz";
// Add custom HTTP headers (e.g., API key or Bearer token)
renderer.RenderingOptions.CustomHttpRequestHeaders["Authorization"] = "Bearer eyJhbGciOi...";
var pdf = renderer.RenderUrlAsPdf("https://app.example.com/dashboard");
pdf.SaveAs("dashboard.pdf");
Imports IronPdf
Dim renderer As New ChromePdfRenderer()
' Add session cookies
renderer.RenderingOptions.CustomCookies("sessionId") = "abc123token"
renderer.RenderingOptions.CustomCookies("authToken") = "bearer-xyz"
' Add custom HTTP headers (e.g., API key or Bearer token)
renderer.RenderingOptions.CustomHttpRequestHeaders("Authorization") = "Bearer eyJhbGciOi..."
Dim pdf = renderer.RenderUrlAsPdf("https://app.example.com/dashboard")
pdf.SaveAs("dashboard.pdf")
HttpClient to authenticate first, then pass the resulting cookies to the CustomCookies dictionary for rendering the protected page.RELATED HOW-TO Article: How to Convert HTML Behind Login Authentication to PDF
4. How to Deploy HTML to PDF on Cloud Plataformas
Deploying HTML to PDF conversion in cloud environments requires specific configuration for headless rendering, temporary file paths, and resource allocation. This section covers the most common cloud platforms and containerized deployments with IronPDF.
| Plataforma | Min Resources | Package | AutoConfig | Temp Path | Key Gotcha |
|---|---|---|---|---|---|
| Azure App Service | B1 tier (Basic) | IronPdf.Linux |
true
|
/tmp | Free/Shared tiers fail — no GPU, low memory |
| Azure Functions (Windows) | B1 tier | IronPdf |
true
|
/tmp | Uncheck "Run from package file" |
| AWS Lambda | 512 MB / 330s timeout | IronPdf.Linux |
true
|
/tmp (required) | Default filesystem is read-only |
| Docker (Ubuntu/Debian) | Image-dependent | IronPdf.Linux |
false
|
Image default |
Set false — Dockerfile handles deps
|
How to Deploy on Azure
When deploying to Azure Functions or App Service, disable GPU acceleration and ensure your hosting tier provides enough memory for Chrome-based rendering. Add these settings at application startup, before any rendering calls.
Azure sandboxes run headless with no GPU access, and Free/Shared tiers (F1, D1) lack the resources Chrome requires. Target a B1 (Basic) tier or higher.
var renderer = new ChromePdfRenderer();
// Azure sandboxes block GPU access — always disable
IronPdf.Installation.ChromeGpuMode = IronPdf.Engines.Chrome.ChromeGpuModes.Disabled;
// Required on non-GUI Linux systems
IronPdf.Installation.LinuxAndDockerDependenciesAutoConfig = true;
var renderer = new ChromePdfRenderer();
var pdf = renderer.RenderHtmlAsPdf("<h1>Azure PDF Report</h1>");
pdf.SaveAs("azure-report.pdf");
var renderer = new ChromePdfRenderer();
// Azure sandboxes block GPU access — always disable
IronPdf.Installation.ChromeGpuMode = IronPdf.Engines.Chrome.ChromeGpuModes.Disabled;
// Required on non-GUI Linux systems
IronPdf.Installation.LinuxAndDockerDependenciesAutoConfig = true;
var renderer = new ChromePdfRenderer();
var pdf = renderer.RenderHtmlAsPdf("<h1>Azure PDF Report</h1>");
pdf.SaveAs("azure-report.pdf");
Imports IronPdf
Dim renderer As New ChromePdfRenderer()
' Azure sandboxes block GPU access — always disable
IronPdf.Installation.ChromeGpuMode = IronPdf.Engines.Chrome.ChromeGpuModes.Disabled
' Required on non-GUI Linux systems
IronPdf.Installation.LinuxAndDockerDependenciesAutoConfig = True
Dim pdf = renderer.RenderHtmlAsPdf("<h1>Azure PDF Report</h1>")
pdf.SaveAs("azure-report.pdf")
RELATED GET-STARTED Guide: How to Deploy IronPDF on Azure
How to Deploy on AWS Lambda
AWS Lambda requires Docker-based deployment for Chrome-based PDF rendering. The default Lambda filesystem is read-only, so all temp and deployment paths must point to /tmp.
Configure these settings at the top of your function handler, before any rendering calls.
using Amazon.Lambda.Core;
var renderer = new ChromePdfRenderer();
public class PdfFunction
{
public string FunctionHandler(string input, ILambdaContext context)
{
// Lambda's only writable directory
var tmpPath = "/tmp/";
IronPdf.Installation.TempFolderPath = tmpPath;
IronPdf.Installation.CustomDeploymentDirectory = tmpPath;
IronPdf.Installation.ChromeGpuMode = IronPdf.Engines.Chrome.ChromeGpuModes.Disabled;
// Let IronPDF install Chrome dependencies on first cold start
IronPdf.Installation.LinuxAndDockerDependenciesAutoConfig = true;
context.Logger.LogLine("Rendering PDF...");
var renderer = new ChromePdfRenderer();
var pdf = renderer.RenderHtmlAsPdf(input);
// Save to /tmp before uploading to S3 or returning
var outputPath = $"{tmpPath}output.pdf";
pdf.SaveAs(outputPath);
return outputPath;
}
}
using Amazon.Lambda.Core;
var renderer = new ChromePdfRenderer();
public class PdfFunction
{
public string FunctionHandler(string input, ILambdaContext context)
{
// Lambda's only writable directory
var tmpPath = "/tmp/";
IronPdf.Installation.TempFolderPath = tmpPath;
IronPdf.Installation.CustomDeploymentDirectory = tmpPath;
IronPdf.Installation.ChromeGpuMode = IronPdf.Engines.Chrome.ChromeGpuModes.Disabled;
// Let IronPDF install Chrome dependencies on first cold start
IronPdf.Installation.LinuxAndDockerDependenciesAutoConfig = true;
context.Logger.LogLine("Rendering PDF...");
var renderer = new ChromePdfRenderer();
var pdf = renderer.RenderHtmlAsPdf(input);
// Save to /tmp before uploading to S3 or returning
var outputPath = $"{tmpPath}output.pdf";
pdf.SaveAs(outputPath);
return outputPath;
}
}
Imports Amazon.Lambda.Core
Dim renderer As New ChromePdfRenderer()
Public Class PdfFunction
Public Function FunctionHandler(input As String, context As ILambdaContext) As String
' Lambda's only writable directory
Dim tmpPath As String = "/tmp/"
IronPdf.Installation.TempFolderPath = tmpPath
IronPdf.Installation.CustomDeploymentDirectory = tmpPath
IronPdf.Installation.ChromeGpuMode = IronPdf.Engines.Chrome.ChromeGpuModes.Disabled
' Let IronPDF install Chrome dependencies on first cold start
IronPdf.Installation.LinuxAndDockerDependenciesAutoConfig = True
context.Logger.LogLine("Rendering PDF...")
Dim renderer As New ChromePdfRenderer()
Dim pdf = renderer.RenderHtmlAsPdf(input)
' Save to /tmp before uploading to S3 or returning
Dim outputPath As String = $"{tmpPath}output.pdf"
pdf.SaveAs(outputPath)
Return outputPath
End Function
End Class
RELATED GET-STARTED Guide: How to Deploy IronPDF on AWS Lambda
How to Deploy with Docker
For Docker deployments, use the IronPdf.Linux NuGet package to reduce image size and avoid runtime asset downloads. This package includes pre-bundled Linux-native binaries optimized for containerized environments.
Set LinuxAndDockerDependenciesAutoConfig = false when your Dockerfile already installs Chrome's shared-library dependencies via apt-get. The runtime auto-install is redundant in that case and can cause permission errors or longer cold starts.
| Plataforma | Package | Key Configuration |
|---|---|---|
| Ubuntu 22.04 / Debian | IronPdf.Linux | Default — works out of the box |
| Alpine Linux | IronPdf.Linux | Install chromium via apk in Dockerfile |
| Amazon Linux 2 | IronPdf.Linux |
Use LinuxAndDockerDependenciesAutoConfig = true
|
| Windows Containers | IronPdf | No additional configuration required |
A minimal multi-stage Dockerfile for an Ubuntu/Debian-based image:
FROM mcr.microsoft.com/dotnet/sdk:8.0 AS build
WORKDIR /app
COPY . .
RUN dotnet publish -c Release -o /out
FROM mcr.microsoft.com/dotnet/aspnet:8.0
# Install Chrome dependencies for PDF rendering
RUN apt-get update && apt-get install -y \
libglib2.0-0 libnss3 libatk1.0-0 libatk-bridge2.0-0 \
libcups2 libdrm2 libxkbcommon0 libxcomposite1 \
libxdamage1 libxrandr2 libgbm1 libpango-1.0-0 \
libcairo2 libasound2 libxshmfence1 && \
rm -rf /var/lib/apt/lists/*
WORKDIR /app
COPY --from=build /out .
ENTRYPOINT ["dotnet", "MyApp.dll"]
var renderer = new ChromePdfRenderer();
// Dependencies handled by Dockerfile apt-get — disable runtime install
IronPdf.Installation.LinuxAndDockerDependenciesAutoConfig = false;
// No GPU in containers
IronPdf.Installation.ChromeGpuMode = IronPdf.Engines.Chrome.ChromeGpuModes.Disabled;
var renderer = new ChromePdfRenderer();
var pdf = renderer.RenderHtmlAsPdf("<h1>Dockerized PDF</h1>");
pdf.SaveAs("output.pdf");
var renderer = new ChromePdfRenderer();
// Dependencies handled by Dockerfile apt-get — disable runtime install
IronPdf.Installation.LinuxAndDockerDependenciesAutoConfig = false;
// No GPU in containers
IronPdf.Installation.ChromeGpuMode = IronPdf.Engines.Chrome.ChromeGpuModes.Disabled;
var renderer = new ChromePdfRenderer();
var pdf = renderer.RenderHtmlAsPdf("<h1>Dockerized PDF</h1>");
pdf.SaveAs("output.pdf");
Imports IronPdf
Dim renderer As New ChromePdfRenderer()
' Dependencies handled by Dockerfile apt-get — disable runtime install
IronPdf.Installation.LinuxAndDockerDependenciesAutoConfig = False
' No GPU in containers
IronPdf.Installation.ChromeGpuMode = IronPdf.Engines.Chrome.ChromeGpuModes.Disabled
Dim pdf = renderer.RenderHtmlAsPdf("<h1>Dockerized PDF</h1>")
pdf.SaveAs("output.pdf")
RELATED GET-STARTED Guide: How to Use IronPDF with Docker
5. Compare IronPDF with Other .NET PDF Libraries
IronPDF es la solución preferida para muchos equipos cuando se trata de generación de PDF en C# gracias a su robusto motor de renderizado potenciado por Chromium, APIs intuitivas y mejoras frecuentes de producto. Compararemos IronPDF con otros convertidores de PDF para encontrar la mejor solución para sus necesidades de generación de PDF.
Matriz de decisión rápida: IronPDF frente a otros convertidores de PDF .NET
| Solución | Cuándo utilizarlo | Mejor para |
|---|---|---|
| IronPDF | Conversión de sitios web modernos/HTML a PDF con fidelidad visual exacta. | Aplicaciones empresariales que requieren un motor de renderizado HTML confiable, contenido dinámico y soporte profesional. |
| wkhtmltopdf | Conversión de HTML simple en aplicaciones no críticas donde la representación obsoleta es aceptable. | Generación básica de documentos con HTML/CSS heredado. |
| Fusión de sincronización | Cuando ya haya invertido en el ecosistema Syncfusion o sea elegible para obtener una licencia comunitaria gratuita. | Organizaciones que utilizan múltiples componentes de Syncfusion. |
| Aspose.PDF | Manipulación compleja de PDF cuando la calidad de representación HTML es menos crítica. | Amplias funciones de edición de PDF más allá de la conversión a HTML. |
COMPARACIONES RELACIONADAS:
Comparación detallada: IronPDF frente a otros convertidores de PDF .NET
| Función | ★ Recomendado IronPDF | wkhtmltopdf | iText 7 | Aspose.PDF | Syncfusion | Apryse | SelectPdf | Spire.PDF | PDFsharp | QuestPDF |
|---|---|---|---|---|---|---|---|---|---|---|
| Rendering & Conversion | ||||||||||
| Precisión de representación | Lo mejor en píxeles perfectos | Estilo de impresión | Sólo programático | Bien | Bien | Bien | Bien | Nivel bajo | Sin renderizado | Diseño basado en código |
| Compatibilidad con HTML5 | Lleno | Anticuado | Añadir | Parcial | Lleno | Módulo | Lleno | Limitado | No | No (Código primero) |
| Compatibilidad con CSS3 | Lleno | Limitado | Añadir | Parcial | Lleno | Módulo | Lleno | Limitado | No | No (Código primero) |
| Ejecución de JavaScript | Mejor completo | No | No | Cuestionado | Limitado | Limitado | Limitado | Muy limitado | No | No |
| HTML→PDF (Diseño moderno) | Chromium integrado Best | Qt WebKit (obsoleto) | Complemento de pago | Parcial; JS Disputado | Motor Blink | Requiere módulo | HTML→PDF completo | Basado en imágenes | No | No es un renderizador HTML |
| PDF→Renderizado de imágenes | Sí | No | Módulo separado | Producto separado | Sí | Sí | No | Limitado | No | Solo documentos propios |
| Operaciones de documentos | ||||||||||
| Generar archivos PDF mediante programación | Sí | No | Sí | Sí | Sí | Sí | Sólo HTML | Sí | Básico | Sí (API fluida) |
| Merge, Split & Rearrange | Sí | No | Sí | Sí | Sí | Sí | Sí | Sí | Limitado | Sí |
| Encabezados / Pies de página / Números de página | HTML/Texto/Imagen Mejor | Limitado | Sí | Vía Eventos | Vía Eventos | Sí | Plantillas | Manual | Solo manual | Tragamonedas de primera clase |
| Watermarks & Stamping | Texto e imagen | No | Sí | Sí | Sí | Sí | Sí | Limitado | No | Sí (superposiciones) |
| Extraer texto de PDFs | Sí | No | Sí | Sí | Sí | Sí | Sí | Sí | Básico | No |
| OCR para archivos PDF escaneados | A través de IronOCR integrado | No | Añadir | Producto separado | Añadir | Añadir | No | Solución alternativa | No | No |
| Security & Compliance | ||||||||||
| Firmas Digitales | Sí | No | Sí | Sí | Sí | Código de muestra | Sí | No | No | No documentado |
| Cumplimiento de PDF/A | Sí (PDF/A-3B) | No | PDF/A completo | Validar y crear | Requiere SDK nativo | Cumplimiento de PDFA | No | Sí | Limitado | PDF/A-2x y 3x |
| Plataforma & Developer Experience | ||||||||||
| Multiplataforma | Windows · Linux · macOS Los 3 | Depende de los binarios | .NET Standard 2.0 | Configuración adicional de Linux | Servidor Blink + .NET | SDK nativo | Sólo Windows * | Documentación limitada de Linux | Centrado en Windows | Windows/Linux/MacOS |
| Cloud & Docker Deploy | Azure · AWS · Docker Mejor | Complejo; Legado | Paquetes múltiples | Parcial; Contenedores | Se necesitan extras de Blink | Departamentos nativos | Sólo para Windows | Información limitada | Simple; ligero | Docker/K8s; Local |
| Support & Documentación | ||||||||||
| Documentación | Extenso + Copiar/Pegar Mejor | Documentación parcial de la CLI | Extenso; KB | Amplio; GitHub | Centro de ayuda | Catálogo multilingüe | Guías de introducción | Guía del programa | Guías de la comunidad | Aplicación estructurada y complementaria |
| Soporte a desarrolladores | Los mejores ingenieros 24/7 | Solo para la comunidad | Suscripción incluida | Foro + Pago | Tracción directa 24/5 | Comercial | Foro + Correo electrónico | Solo para la comunidad | Comunidad + GitHub | |
| Licensing & Pricing | ||||||||||
| Modelo de licencia | Perpetuo | Código abierto | AGPL / Suscripción | Perpetuo | Suscripción anual | Costumbre / Consumo | Perpetuo | Suscripción anual | Gratis (MIT) | Niveles gratuitos y de pago del MIT |
| Precio inicial | 9Perpetual · 1 Developer | style="color:#16a34a">Gratis | Cotización personalizada de ~$45 000/año | $1,175+ por desarrollador | Suscripción de $995/año · Gratis <$1M | Cotización personalizada de más de $9000 al año | $499+ Perpetuo | Suscripción anual de $999/año | style="color:#16a34a">Gratis | Comunidad style="color:#16a34a">gratuita MIT < millón |
| Prueba gratuita | 30 días · Funciones completas sin límites | N/A (Gratis) | 30 días | Sí (con marca de agua) | Community <$1M Rev | Sí | Comunidad (5 páginas) | Gratis (10 páginas) | N/A (Gratis) | N/A (MIT Free <$1M) |
| Transparencia de precios | Publicado y claro mejor | Código abierto | AGPL complejo | Muchos niveles | Contacto para cotización | Sin precios publicados | Publicado | Publicado | MIT; Sin restricciones | MIT; Basado en la confianza |
Comparación de conversión de HTML a PDF en la vida real: Representación de la página de inicio de Reddit
Para evaluar la calidad del PDF de salida, probamos estas bibliotecas con la página principal de Reddit que contiene contenido web dinámico, CSS moderno y elementos HTML de JavaScript. Esta página sirve como un caso de prueba ideal para la generación de PDF de salida.

IronPDF

IronPDF ofrece resultados pixel-perfect, preservando todo el contenido web dinámico, el estilo de fuentes web modernas y los elementos interactivos exactamente como se muestran en Chrome, todo en tan solo unas pocas líneas de código.
Syncfusion

Syncfusion renderizó el PDF con la mayoría de las secciones y estilos ausentes, especialmente el contenido dinámico. Inicialmente bloqueado por la seguridad de Reddit. Lograr mejores resultados requiere una extensa configuración de línea de comandos, pero la salida sigue siendo incompleta.
Aspose.PDF

Aspose.PDF requirió primero una descarga manual de HTML (sin soporte para URL directo). Después de la conversión, el resultado carecía de un formato adecuado y se perdieron casi todas las secciones de contenido, lo que lo hace inadecuado para la web moderna con contenido dinámico.
wkhtmltopdf

wkhtmltopdf se completó rápidamente, pero produjo una página plana y estática que carece de contenido crítico como actualizaciones en vivo, elementos dinámicos y secciones interactivas. Esto demuestra la incompatibilidad de wkhtmltopdf con sitios web modernos impulsados por JavaScript.
Conclusión sobre el rendimiento y la calidad del PDF de salida
Para los desarrolladores .NET que necesitan un conversor confiable de HTML a PDF, IronPDF se destaca con un código mínimo, APIs fáciles de usar y mejoras frecuentes del producto.
En una prueba del mundo real en contenido web, ofreció los resultados más rápidos y precisos, mientras que Syncfusion quedó rezagado, Aspose requirió pasos adicionales y wkhtmltopdf careció de estilo moderno. IronPDF ofrece el mejor equilibrio de velocidad, precisión y simplicidad para los flujos de trabajo de conversión de HTML a PDF de hoy.
Por favor note: Aspose, SyncFusion y wkhtmltopdf son marcas comerciales de sus respectivos propietarios. Este sitio no está afiliado ni es patrocinado por ellos. Todos los nombres, logotipos y marcas pertenecen a sus propietarios, y las comparaciones se basan en la información públicamente disponible al momento de escribir.
Resumen
Esta guía cubrió todo lo necesario para convertir HTML a PDF en .NET: desde la conversión básica de cadenas hasta funciones avanzadas como procesamiento asíncrono, firmas digitales y generación de lotes. Demostramos tres métodos de conversión, configuraciones esenciales, funciones avanzadas y configuraciones de seguridad, y comparamos IronPDF con otras bibliotecas mediante pruebas del mundo real de generación de documentos dinámicos.
Mientras los competidores lucharon con sitios web modernos o requerían soluciones complejas, IronPDF ofreció resultados impecables con un código mínimo y un potente motor de renderización.
¿Listo para simplificar tu flujo de trabajo de PDF y experimentar una generación versátil de PDF en solo unas pocas líneas de código? Instala IronPDF a través del Administrador de Paquetes NuGet (o selecciona Administrar Paquetes NuGet en Visual Studio) y convierte tu primer HTML a PDF hoy.
Comienza tu prueba gratuita de 30 días para realizar pruebas de producción sin marcas de agua. Flexible licensing starts at $799 with transparent team pricing that scales with your needs.
6. Troubleshooting & Technical Support
¿Tienes problemas con los siguientes errores en la conversión de HTML a PDF? IronPDF ofrece soporte de ingenieros 24/7 mediante el widget de chat en https://ironpdf.com/
Soluciones rápidas a errores comunes
- ¿Lenta primera renderización? Normal. Chrome se inicializa en 2–3s, luego acelera.
- ¿Problemas en la nube? Usa al menos Azure B1 o recursos equivalentes.
- ¿Recursos faltantes? Configura rutas base o incrusta como base64.
- ¿Elementos faltantes? Agrega RenderDelay para la ejecución de JavaScript.
- ¿Memoria en renderización? Actualiza a v2025.9.4 para correcciones en HTML a PDF, sellos y encabezados/pies.
- ¿Problemas con campos de formulario (p.ej., áreas de texto largas, casillas de verificación)? Corregido en v2025.7.17; asegúrate de nombres únicos para casillas de verificación.
- ¿Recorte de encabezado/pie personalizado o caracteres especiales corruptos? Resuelto en v2025.8.8; prueba el ajuste de palabras y metadatos.
Obtenga ayuda de los ingenieros que construyeron IronPDF, 24/7
- Guía completa de solución de problemas
- Estrategias de optimización del rendimiento
- Solicitudes de soporte de ingeniería
- Lista de verificación rápida para la resolución de problemas
Próximos pasos
Preguntas Frecuentes
¿Cómo convierto HTML a PDF en C#?
Puedes convertir HTML a PDF en C# utilizando una biblioteca de renderizado de Chrome que convierte HTML, CSS3 y JavaScript en PDF perfectos. Herramientas como IronPDF permiten renderizar a partir de URL, cadenas HTML o archivos y admiten cabeceras, autenticación y ajustes de impresión.
¿Cuál es la mejor biblioteca HTML a PDF for .NET?
La mejor biblioteca debería admitir la representación precisa de Chrome, la implementación multiplataforma y las características empresariales. IronPDF cubre todo esto: funciona en Windows, Linux, macOS y Docker, con soporte para seguridad, firmas, cumplimiento y aplicaciones escalables .NET.
¿Cómo puedo convertir cadenas HTML a PDF usando C#?
Para convertir cadenas HTML a PDF, usa la clase ChromePdfRenderer y su método RenderHtmlAsPdf. Pasa tu cadena HTML a este método, luego guarda el PDF usando SaveAs.
¿Cuáles son los pasos para convertir una URL de página web a un documento PDF en C#?
Puedes convertir una URL de página web directamente en un PDF usando el método RenderUrlAsPdf, lo que te permite conservar estilos, imágenes y elementos interactivos como formularios e hipervínculos.
¿Cómo convierto un archivo HTML a PDF en C#?
Usa ChromePdfRenderer.RenderHtmlFileAsPdf("path/to/file.html") para convertir archivos HTML locales a PDF. IronPDF resuelve automáticamente todas las rutas de recursos relativos (imágenes, CSS, JS).
¿Cómo convierto las Razor Pages de ASP.NET o las Vistas MVC a PDF?
IronPDF proporciona paquetes de extensiones dedicados — IronPdf.Extensions.Razor para Razor Pages y IronPdf.Extensions.Mvc.Core para Vistas MVC. Usa RenderRazorToPdf o RenderRazorViewToPdf con inyección de dependencias para convertir vistas directamente a PDF desde tus controladores. Ver guía de Razor →
¿Cómo aseguro que el contenido JavaScript se renderice correctamente en el PDF?
Habilita la representación de JavaScript configurando RenderingOptions.EnableJavaScript = true y agrega un retraso de renderizado usando RenderingOptions.WaitFor.RenderDelay para asegurar que el contenido dinámico esté completamente cargado antes de la conversión. Ver guía de WaitFor →
¿Cuál es el mejor método para agregar encabezados y pies de página a un PDF en C#?
Usa la clase TextHeaderFooter para encabezados y pies de página de texto simples, o la clase HtmlHeaderFooter para contenido HTML más complejo. Puedes incluir marcadores de posición dinámicos como {page}, {total-pages} y {date} para generación automática de contenido. Ver guía de encabezados y pies de página →
¿Cómo manejo saltos de página en la salida del PDF en C# .NET?
Controla los saltos de página en tus PDFs utilizando propiedades CSS como page-break-after: always y page-break-inside: avoid dentro de un bloque de media de impresión CSS. Ver guía de saltos de página →
¿Qué opciones están disponibles para configurar el tamaño del papel y la orientación en los PDFs?
Configura el tamaño del papel usando RenderingOptions.PaperSize (las opciones incluyen A4, Carta, Legal, etc.) y la orientación con RenderingOptions.PaperOrientation para Retrato o Paisaje. También se admiten tamaños personalizados en milímetros o pulgadas. Ver guía de tamaño de papel →
¿Puedo convertir páginas web autenticadas a PDF?
Sí. IronPDF admite cookies, encabezados HTTP personalizados y autenticación basada en formularios. Configura las cookies a través de ChromePdfRenderer.RenderingOptions.CustomCookies, o pasa encabezados de autenticación para autenticación basada en tokens. También se admite la autenticación Windows NTLM y Kerberos. Ver guía de cookies →
¿Puedo crear múltiples PDFs a partir de una plantilla HTML única en C#?
Sí, crea plantillas HTML con marcadores de posición, luego usa reemplazo de cadenas o bibliotecas de plantillado como Handlebars.NET. Sustituye los marcadores de posición con valores reales en tus datos iterados y genera PDFs usando RenderHtmlAsPdf.
¿Es posible asegurar mis PDFs generados con una contraseña?
Sí, puedes usar la propiedad SecuritySettings para configurar contraseñas de usuario y propietario, configurar permisos como imprimir y copiar, y aplicar cifrado AES256 con SecuritySettings.EncryptionAlgorithm. Ver guía de cifrado →
¿Puedo generar documentos compatibles con PDF/A desde HTML?
Sí. IronPDF admite los estándares PDF/A-1b, PDF/A-2b, PDF/A-3b y PDF/UA para cumplimiento de archivo y accesibilidad, lo cual la mayoría de los convertidores HTML a PDF no ofrecen. Ver guía PDF/A →
¿Cómo puedo optimizar el rendimiento para generar un gran volumen de PDFs?
Optimiza el rendimiento usando métodos asincrónicos como RenderHtmlAsPdfAsync para operaciones no bloqueantes. Reutiliza instancias de ChromePdfRenderer, procesa múltiples PDFs de forma concurrente utilizando Task.WhenAll, y asegúrate de tener recursos de servidor adecuados en un sistema de 64 bits. Ver guía asincrónica →
¿Cómo puedo combinar múltiples PDFs o incluir una página de portada en mi documento?
Usa el método estático PdfDocument.Merge para combinar múltiples PDFs. Genera tu página de portada por separado y combínala con tu documento principal para crear un PDF completo. Ver guía de combinación →
¿Puedo desplegar IronPDF en Azure, AWS, o Docker?
Sí. IronPDF funciona en Azure App Service, Azure Functions, AWS Lambda y contenedores Docker en Linux. Guías de configuración dedicadas e imágenes Docker están disponibles para cada plataforma. Ver guía de Azure → · Ver guía de AWS → · Ver guía de Docker →
Compatibilidad con .NET 10: ¿IronPDF admite .NET 10 de inmediato?
Sí — IronPDF es totalmente compatible con .NET 10. Según las notas de lanzamiento de IronPDF, la biblioteca está lista desde el primer día para proyectos .NET 10, sin necesidad de configuración adicional. Ya sea que estés utilizando aplicaciones web, de consola, de escritorio, o microservicios, IronPDF funciona "out of the box" con .NET 10.
¿Es IronPDF gratuito?
IronPDF ofrece una prueba gratuita de 30 días con funcionalidad completa y sin marcas de agua en el desarrollo. El uso en producción requiere una licencia comercial a partir de $749. Están disponibles los niveles Lite, Plus, Professional y Enterprise. Ver precios →
¿Cómo se compara la calidad de representación de esta biblioteca con otras opciones como wkhtmltopdf?
Esta biblioteca usa un motor de renderizado Chrome moderno para PDFs perfectos en píxeles, a diferencia del desactualizado motor WebKit de wkhtmltopdf. No requiere ejecutables de servidor, soporta JavaScript/CSS3 completo, recibe actualizaciones regulares y ofrece soporte profesional.
¿Por qué debería elegir esta biblioteca en lugar de PDFSharp para la conversión de HTML a PDF?
PDFSharp carece de conversión HTML a PDF integrada, requiriendo soluciones complicadas. Esta biblioteca ofrece conversión directa de HTML/URL/archivo con una API de alto nivel, soporte para tecnologías web modernas y actualizaciones regulares con soporte profesional. Ver comparación con PDFSharp →
¿Por qué es esta una mejor opción que iTextSharp para la conversión de HTML?
La versión gratuita de iTextSharp no admite la conversión nativa de HTML a PDF y tiene una API de bajo nivel compleja. Esta biblioteca proporciona una conversión de HTML sin problemas con una API intuitiva, soporte completo para CSS3/JavaScript, y sin restricciones de licencia AGPL. Ver comparación con iTextSharp →
¿Cómo se compara la calidad de renderizado de esta biblioteca con Aspose.PDF?
Esta biblioteca produce PDFs de calidad Chrome perfectamente pixelada, mientras que Aspose.PDF a menudo omite estilos y contenido dinámico. Aspose requiere descargas HTML manuales para la conversión de URL, pero esta biblioteca convierte URLs directamente con mayor precisión. Ver comparación con Aspose →
¿Por qué podría elegir esta biblioteca sobre Syncfusion PDF?
Si bien Syncfusion es capaz, el motor optimizado de Chrome de esta biblioteca funciona más rápido y maneja el contenido dinámico de manera más efectiva. Ofrece una API más sencilla y características adicionales como generación de OCR y código de barras. Ver comparación con Syncfusion →

