Conversión de HTML a PDF en .NET Core Tutorial

This article was translated from English: Does it need improvement?
Translated
View the article in English

IronPDF

Generador de PDF .NET Core

Crear archivos PDF en .NET Core es una tarea engorrosa. Trabajar con PDF en proyectos ASP.NET MVC, así como convertir vistas MVC, archivos HTML y páginas web en línea a PDF puede ser todo un reto. Este tutorial trabaja con la herramienta IronPDF para abordar estos problemas, proporcionando directrices instructivas para muchas de sus necesidades PDF .NET.

IronPDF también soporta la depuración de su HTML con Chrome para Pixel Perfect PDFs. Encontrará un tutorial para configurarlo aquí.


Visión general

Después de este tutorial, serás capaz de:

  • Convierte a PDF desde diferentes fuentes como URL, HTML, vistas MVC
  • Utiliza las opciones avanzadas para diferentes configuraciones de salida de PDF
  • Implanta tu proyecto en Linux y Windows
  • Trabajar con funciones de manipulación de documentos PDF
  • Añadir encabezados y pies de página, fusionar archivos, añadir sellos
  • Trabaja con Dockers

    Esta amplia gama de funciones de HTML a PDF de .NET Core le ayudará con toda una serie de necesidades de proyecto.


    Primer paso

1. Instale la biblioteca IronPDF

Biblioteca NuGet C# para PDF

Instalar con NuGet

Install-Package IronPdf
o
Java PDF JAR

Descargar DLL

Descargar DLL

Instalar manualmente en su proyecto

IronPDF puede instalarse y utilizarse en todos los tipos de proyectos .NET, como aplicaciones Windows, ASP.NET MVC y aplicaciones .NET Core.

Para añadir la librería IronPDF a nuestro proyecto tenemos dos formas, o bien desde el editor de Visual Studio instalar usando NuGet, o bien con una línea de comandos usando el gestor de consola de paquetes.

Instalación con NuGet

Para añadir la librería IronPDF a nuestro proyecto utilizando NuGet, podemos utilizar la interfaz visualizada (Gestor de paquetes NuGet) o mediante un comando de la consola del gestor de paquetes:

1.1.1 Uso del gestor de paquetes NuGet

1- Click derecho sobre el nombre del proyecto -> Seleccionar Manage NuGet Package2- Desde la pestaña del navegador -> busca IronPdf -> Instalar3- Haga clic en Ok4- ¡Hecho!

1.1.2 Uso del gestor de la consola de paquetes NuGet

1- Desde Herramientas -> Gestor de Paquetes NuGet -> Consola del Gestor de Paquetes2- Ejecutar comando -> Install-Package IronPdf

Tutoriales prácticos

## 2. Convertir página web a PDF Ejemplo: Aplicación de consola ConvertUrlToPdf

Siga estos pasos para crear un nuevo proyecto Asp.NET MVC


1- Abrir Visual Studio2- Seleccione Crear nuevo proyecto3- Elige Console App (.NET Core)4- Dale a nuestro ejemplo el nombre "ConvertUrlToPdf" y pulsa crear5- Ahora tenemos una aplicación de consola creada6- Añade IronPdf => haz clic en instalar

7- Añadir nuestras primeras líneas que renderizan una página principal del sitio web Wikipedia a PDF

```cs :path=/static-assets/pdf/content-code-examples/tutorials/dotnet-core-pdf-generating-1.cs ```

8- Ejecute y compruebe el archivo creado wiki.pdf
## 3. Convertir .NET Core HTML a PDF

Muestra: Aplicación de consola ConvertHTMLToPdf

Para convertir HTML en PDF tenemos dos formas:
1- Escribir HTML en cadena y luego renderizarlo
2- Escribir HTML en un archivo y pasarle la ruta a IronPDF para que lo renderice.

La representación del código de ejemplo de la cadena HTML tendrá el siguiente aspecto.

```cs :path=/static-assets/pdf/content-code-examples/tutorials/dotnet-core-pdf-generating-2.cs ```

Y el PDF resultante tendrá este aspecto.


## 4. Convertir vista MVC a PDF **Ejemplo: TicketsApps .NET Core MVC Application** Pongamos un ejemplo de la vida real. He elegido un sitio de venta de entradas en línea. Abra el sitio, navegue hasta "reservar entrada", rellene la información requerida y, a continuación, descargue su copia en formato PDF. Vamos a seguir estos pasos: - [Crear un proyecto](#anchor-create-project) - [Crear un modelo de objetos cliente](#anchor-add-client-model) - [Crear servicios para clientes (añadir, ver)](#anchor-add-client-services) - [Diseño de la página de reserva de entradas](#anchor-design-ticket-booking-page) - [Validar y guardar la información de la reserva](#anchor-validate-and-save-the-booking-information) - [Descargar billete PDF](#anchor-download-pdf-ticket) ### Crear proyecto 1. Seleccione "ASP.NET Core Web App (Modelo-Vista-Controlador)". 2. Nombra el proyecto "TicketsApps" 3. Usemos .NET 8 con Linux Docker habilitado. Dentro del Dockerfile, cambia de "USER app" a "USER root". Esto garantizará que se conceden suficientes permisos a la biblioteca. 4. Ya está listo. ### Añadir modelo de cliente 1. Haga clic con el botón derecho en la carpeta "Modelos" y añada una clase. 2. Nombre el modelo "ClientModel" y haga clic en añadir. 3. Añade los atributos 'name', 'phone' y 'email' a la clase ClientModel. Haz que todos sean obligatorios añadiendo el atributo 'Required' sobre cada uno de ellos como sigue: ```cs :path=/static-assets/pdf/content-code-examples/tutorials/dotnet-core-pdf-generating-3.cs ``` ### Añadir servicios al cliente 1. Crea una carpeta y nómbrala "servicios" 2. Añade una clase llamada "ClientServices" 3. Añade un objeto estático de tipo "ClientModel" para utilizarlo como repositorio. 4. Añade dos funciones: una para guardar clientes en el repositorio, y la segunda para recuperar clientes guardados. ```cs :path=/static-assets/pdf/content-code-examples/tutorials/dotnet-core-pdf-generating-4.cs ``` ### Diseño de la página de reserva de entradas 1. Desde el explorador de soluciones, haga clic con el botón derecho en la carpeta "Controladores" y añada un controlador. 2. Nómbralo "BookTicketController" 3. Haga clic con el botón derecho en la función de índice (o como lo llamamos acción) y elija "Añadir vista" 4. Añade una Vista llamada "índice" 5. Actualice el HTML del siguiente modo ```cs :path=/static-assets/pdf/content-code-examples/tutorials/dotnet-core-pdf-generating-5.cs ``` 6. Añadir un enlace de navegación que permita a los visitantes de nuestro sitio web navegar hasta nuestra nueva página de reservas. Esto puede hacerse actualizando el diseño en la ruta existente (Vistas -> Compartidas -> \_Layout.cshtml). Añade el siguiente código: ```html``` 7. El resultado debería ser el siguiente. 8. Vaya a la página "Reservar billete". Debería tener este aspecto: ### Validar y guardar la información de la reserva 1. Añade otra acción de índice con el atributo [HttpPost] para informar al motor MVC de que esta acción es para enviar datos. Valida el modelo enviado, y si es válido, el código redirigirá al visitante a la página TicketView. Si no es válida, el visitante recibirá mensajes de error de validación en la pantalla. ```cs :path=/static-assets/pdf/content-code-examples/tutorials/dotnet-core-pdf-generating-7.cs ``` Ejemplo de mensajes de error 2. Cree un modelo Ticket en el archivo "Modelos" y añada el código siguiente ```cs :path=/static-assets/pdf/content-code-examples/tutorials/dotnet-core-pdf-generating-9.cs ``` 3. Añadir TicketView para mostrar nuestro ticket. Esta vista alojará una vista parcial del ticket que se encargará de mostrar el ticket y que se utilizará posteriormente para imprimir el ticket. ```cs :path=/static-assets/pdf/content-code-examples/tutorials/dotnet-core-pdf-generating-8.cs ``` 4. Haga clic con el botón derecho en la función TicketView, seleccione "Añadir vista" y nómbrela "TicketView". Añade el siguiente código: ```html @model TicketsApps.Models.TicketModel @{ ViewData["Title"] = "TicketView"; } @Html.Partial("_TicketPdf", Model) @using (Html.BeginForm()) { @Html.HiddenFor(c => c.Email) @Html.HiddenFor(c => c.Name) @Html.HiddenFor(c => c.Phone) @Html.HiddenFor(c => c.TicketDate) @Html.HiddenFor(c => c.TicketNumber)
} ``` 5. Haga clic con el botón derecho en el archivo BookTicket, añada otra Vista y nómbrela "\_TicketPdf" Añada el siguiente código: ```html @model TicketsApps.Models.TicketModel @{ Layout = null; }
VIP @Model.TicketNumber Ticket
1
Room Number
Your
Ticket
VIP
Date
@Model.TicketDate.ToShortDateString()
Issued By
Admin
Invite Number
@Model.TicketNumber
``` 6. Añada lo siguiente "[ticket.css](/img/tutorials/dot-net-core/ticket.css)" en el archivo "wwwroot/css". 7. Añada IronPDF al proyecto y acepte la licencia. 8. Añade el método post TicketView que manejará el botón de descarga. ```cs :path=/static-assets/pdf/content-code-examples/tutorials/dotnet-core-pdf-generating-10.cs ``` 9. Cree un controlador en el archivo "Controller" y nómbrelo "ControllerExtensions". Este controlador convertirá la vista parcial en una cadena. Utilice el código de extensión como se indica a continuación: ```cs :path=/static-assets/pdf/content-code-examples/tutorials/dotnet-core-pdf-generating-11.cs ``` 10. Ejecute la aplicación y rellene los datos de la entrada, después haga clic en "Guardar". 11. Ver el billete generado ### Descargar billete PDF Para descargar el billete en formato PDF, haga clic en "Descargar Pdf". Recibirá un PDF con el billete. Puede descargar el código completo de esta guía. Viene como un archivo comprimido que puede abrir en Visual Studio. [Haga clic aquí para descargar el proyecto.](/img/tutorials/dot-net-core/TicketsApps.zip)
## 5. Tabla de opciones de renderizado de PDF de .NET Tenemos algunas opciones avanzadas que definen las opciones de renderizado del PDF, como el ajuste de los márgenes, orientación del papel, tamaño del papel, etc. A continuación encontrará un cuadro que ilustra las distintas opciones.
ClaseChromePdfRenderer
DescripciónPermite definir las opciones de impresión del PDF, como el tamaño del papel, los PPP, los encabezados y los pies de página.
Propiedades / funcionesTipoDescripción
CustomCookiesDictionary<cadena, cadena>Cookies personalizadas para el renderizado HTML. Las cookies no persisten entre renderizaciones y deben configurarse cada vez.
PaperFitVirtualPaperLayoutManagerUn gestor para configurar diseños de papel virtual, controlando cómo se presentará el contenido en las páginas de "papel" PDF. Incluye opciones para Default Chrome Behavior, Zoomed, Responsive CSS3 Layouts, Scale-To-Page & Continuous Feed style PDF page setups.
UseMarginsOnHeaderAndFooterUseMarginsUtilizar los valores de margen del documento principal al representar los encabezados y pies de página.
CreatePdfFormsFromHtmlboolConvierte todos los elementos de formulario HTML en formularios PDF editables. El valor por defecto es true.
CssMediaTipoPdfCssMediaTipoEnables Media="screen" CSS Styles and StyleSheets. Default value is PdfCssMediaTipo.Screen.
CustomCssUrlcadenaPermite aplicar una hoja de estilo CSS personalizada al HTML antes de la visualización. Puede ser una ruta de archivo local o una URL remota. Sólo aplicable al convertir HTML a PDF.
Activar JavaScriptboolPermite ejecutar JavaScript y JSON antes de renderizar la página. Ideal para imprimir desde aplicaciones Ajax / Angular. El valor por defecto es false.
EnableMathematicalLaTexboolPermite la representación de elementos matemáticos LaTeX.
JavascriptcadenaA custom JavaScript cadena to be executed after all HTML has loaded but before PDF rendering.
JavascriptMessageListenerCadenaDelegateUn método de devolución de llamada que se invocará cada vez que un mensaje de la consola JavaScript del navegador esté disponible.
NúmeroPrimeraPáginaintNúmero de la primera página que se utilizará en los encabezados y pies de página del PDF. El valor por defecto es 1.
TablaDeContenidosTablaDeContenidosTiposGenera una tabla de contenidos en el lugar del documento HTML donde se encuentra un elemento con id "ironpdf-toc".
Escala de grisesboolImprime un PDF en blanco y negro. El valor por defecto es false.
Cabecera de textoICabecera de textoFooterEstablece el contenido del pie de página de cada página PDF como texto, admite la fusión de correo y convierte automáticamente las URL en hipervínculos.
Pie de texto
HtmlHeaderHtmlHeaderFooterEstablece el contenido de la cabecera de cada página PDF como HTML. Admite la fusión de correo.
HtmlFooter
Codificación de entradaCodificaciónThe input character encoding as a cadena. Default value is Codificación.UTF8.
MarginTopdobleMargen superior del PDF "papel" en milímetros. Póngalo a cero para aplicaciones sin bordes y de impresión comercial. El valor por defecto es 25.
MarginRightdobleMargen derecho del PDF "papel" en milímetros. Póngalo a cero para aplicaciones sin bordes y de impresión comercial. El valor por defecto es 25.
MarginBottomdobleMargen "papel" inferior del PDF en milímetros. Póngalo a cero para aplicaciones sin bordes y de impresión comercial. El valor por defecto es 25.
MargenIzquierdodobleMargen "papel" izquierdo del PDF en milímetros. Póngalo a cero para aplicaciones sin bordes y de impresión comercial. El valor por defecto es 25.
Orientación del papelPdfOrientación del papelLa orientación del papel PDF, como Vertical u Horizontal. El valor predeterminado es Vertical.
TamañoPapelPdfTamañoPapelEstablece el tamaño del papel
SetCustomTamañoPapelinCentimetersdobleEstablece el tamaño del papel in centimeters.
SetCustomTamañoPapelInInchesEstablece el tamaño del papel in inches.
SetCustomTamañoPapelinMilimetersEstablece el tamaño del papel in millimeters.
SetCustomTamañoPapelinPixelsOrPointsEstablece el tamaño del papel in screen pixels or printer points.
PrintHtmlBackgroundsBooleanooIndica si se imprimen los colores de fondo y las imágenes de HTML. El valor por defecto es true.
RequestContextRequestContextsContexto de la solicitud para este render, determinando el aislamiento de ciertos recursos como las cookies.
Tiempo de esperaEnteroTiempo de espera en segundos. El valor por defecto es 60.
TítuloCadenaPDF Document Name and Título metadata, useful for mail-merge and automatic file naming in the IronPdf MVC and Razor extensions.
ForceTamañoPapelBooleanooForce page sizes to be exactly what is specified via IronPdf.ChromePdfRenderOptions.TamañoPapel by resizing the page after generating a PDF from HTML. Helps correct small errors in page size when rendering HTML to PDF.
Espere enEspere enUn objeto envoltorio que contiene la configuración del mecanismo wait-for para que los usuarios esperen ciertos eventos antes de renderizar. Por defecto, no esperará nada.

## 6. Tabla de opciones de encabezado y pie de página de PDF .NET
ClaseEncabezado de textoPie de página
DescripciónSe utiliza para definir las opciones de visualización del encabezado y pie de texto
Propiedades \ funcionesTipoDescripción
CentrarTextocadenaSet the text in centered/left/right of PDF header or footer. Can also merge metadata using cadenas placeholders: {page}, {total-pages}, {url}, {date}, {time}, {html-title}, {pdf-title}
Textoizquierdo
RightText
DibujarLíneaDivisoriaBooleanoAñade una línea horizontal divisoria entre el encabezado/pie de página y el contenido de la página en cada página del documento PDF.
DibujarLíneaDivisoriaColorColorThe color of the divider line specified for IronPdf.Encabezado de textoPie de página.DibujarLíneaDivisoria.
FuentePdfFuenteFuente family used for the PDF document. Default is IronSoftware.Drawing.FuenteTipos.Helvetica.
FuenteSizeDobleFuente size in pixels.

## 7. Aplicar opciones de impresión PDF (renderizado) Intentemos configurar nuestras opciones de renderizado de PDF. ```cs :path=/static-assets/pdf/content-code-examples/tutorials/dotnet-core-pdf-generating-12.cs ```
## 8. Aplicaciones .NET Core en Docker ### 8.1. ¿Qué es Docker? Docker es un conjunto de productos de plataforma como servicio que utiliza la virtualización a nivel de sistema operativo para ofrecer software en paquetes denominados contenedores. Los contenedores están aislados unos de otros y agrupan su propio software, bibliotecas y archivos de configuración; pueden comunicarse entre sí a través de canales bien definidos. Más información [Aplicación Docker y ASP.NET Core](https://learn.microsoft.com/en-us/aspnet/core/host-and-deploy/docker/building-net-docker-images) aquí. Vamos a pasar a trabajar con Docker, pero si quieres saber más, hay una gran introducción a [.NET y Docker aquí.](https://docs.microsoft.com/en-us/dotnet/core/docker/introduction) y aún más sobre cómo [crear contenedores para aplicaciones .NET core](https://docs.microsoft.com/en-us/dotnet/core/docker/build-container). Empecemos juntos con Docker. ### 8.2. Instalar Docker Visite el sitio web de Docker aquí para [instalar Docker.](https://www.docker.com/) Haz clic en empezar. Haga clic en descargar para Mac y Windows. Regístrate gratis e inicia sesión. Descargar Docker para Windows. Comience a instalar Docker. Será necesario reiniciarlo. Después de que su máquina se reinicie, inicie sesión en Docker. Ahora puedes ejecutar Docker "hola mundo" abriendo la línea de comandos de Windows o el script PowerShell y escribir: Docker ejecuta hello-world Aquí tienes una lista de las líneas de comandos más importantes para ayudarte: - Imágenes Docker => Para listar todas las imágenes disponibles en esta máquina - Docker ps => para listar todos los contenedores en ejecución - Docker ps -a => para listar todos los contenedores ### 8.3. Ejecutar en contenedor Linux
## 9. Trabajar con documentos PDF existentes ### 9.1. Abrir PDF existente Como se puede crear un PDF a partir de URL y HTML (texto o archivo)También puede trabajar con documentos PDF existentes. A continuación se muestra un ejemplo para abrir un PDF normal o un PDF cifrado con contraseña ```cs :path=/static-assets/pdf/content-code-examples/tutorials/dotnet-core-pdf-generating-13.cs ``` ### 9.2. Fusionar varios PDF Puedes fusionar varios PDF en uno solo de la siguiente manera: ```cs :path=/static-assets/pdf/content-code-examples/tutorials/dotnet-core-pdf-generating-14.cs ``` Añada otro PDF al final del PDF actual de la siguiente manera: ```cs :path=/static-assets/pdf/content-code-examples/tutorials/dotnet-core-pdf-generating-15.cs ``` Inserta un PDF en otro PDF empezando por el índice dado: ```cs :path=/static-assets/pdf/content-code-examples/tutorials/dotnet-core-pdf-generating-16.cs ``` ### 9.3 Añadir encabezados o pies de página Puede añadir encabezados y pies de página a un PDF existente o cuando renderice el PDF desde HTML o URL. Hay dos clases que puede utilizar para añadir encabezado o pie de página a un PDF: - TextHeaderFooter: añade texto simple en cabecera o pie de página. - HtmlHeaderFooter: añadir encabezado o pie de página con contenido HTML enriquecido e imágenes. Ahora veamos dos ejemplos de como añadir cabecera/pie a un pdf existente o cuando se renderiza usando estas dos clases. **9.3.1 Añadir cabecera al pdf** existente A continuación se muestra un ejemplo para cargar un PDF existente y, a continuación, añadir un encabezado y un pie de página mediante los métodos `AddTextHeaders` y `AddHtmlFooters`. ```cs :path=/static-assets/pdf/content-code-examples/tutorials/dotnet-core-pdf-generating-17.cs ``` **9.3.2 Añadir encabezado y pie de página a un nuevo pdf** A continuación se muestra un ejemplo para crear un PDF a partir de un archivo HTML y añadirle un encabezado y un pie de página utilizando las opciones de renderizado. ```cs :path=/static-assets/pdf/content-code-examples/tutorials/dotnet-core-pdf-generating-18.cs ```
## 10. Añadir contraseña PDF y seguridad Puede proteger su PDF con una contraseña y editar la configuración de seguridad del archivo, como impedir la copia y la impresión. ```cs :path=/static-assets/pdf/content-code-examples/tutorials/dotnet-core-pdf-generating-19.cs ```
## 11. Firmar PDF digitalmente También puedes firmar digitalmente un PDF de la siguiente manera: ```cs :path=/static-assets/pdf/content-code-examples/tutorials/dotnet-core-pdf-generating-20.cs ``` Ejemplo avanzado para un mayor control: ```cs :path=/static-assets/pdf/content-code-examples/tutorials/dotnet-core-pdf-generating-21.cs ``` ## 12. Extraer texto e imágenes de PDF Extraer texto e imágenes Con IronPdf puede extraer texto e imágenes de un PDF de la siguiente manera: ```cs :path=/static-assets/pdf/content-code-examples/tutorials/dotnet-core-pdf-generating-22.cs ``` ### 12.1. Rasterizar PDF a imagen También puedes convertir páginas PDF en imágenes de la siguiente manera ```cs :path=/static-assets/pdf/content-code-examples/tutorials/dotnet-core-pdf-generating-23.cs ```
## 13. Añadir marca de agua PDF The following is an example of how to watermark PDF pages. ```cs :path=/static-assets/pdf/content-code-examples/tutorials/dotnet-core-pdf-generating-24.cs ``` La marca de agua tiene un conjunto restringido de opciones y funciones. Para un mayor control, puede utilizar la clase **HTMLStamper**. ```cs :path=/static-assets/pdf/content-code-examples/tutorials/dotnet-core-pdf-generating-25.cs ```

Acceso rápido a tutoriales

Obtener el código fuente

Acceda a todo el código fuente que se encuentra en este tutorial como un archivo ZIP de proyecto de Visual Studio, fácil de usar y compartir para su proyecto.

Obtener el código

Acceso al tutorial de GitHub

Explore este tutorial y muchos más a través de GitHub. Utilizar los proyectos y el código fuente es la mejor manera de aprender y aplicarlo a sus propias necesidades y casos de uso de PDF .NET Core.

Generar PDFs en .NET Core Tutorial

Conserve el PDF CSharp Cheat Sheet

Desarrolle PDFS en sus aplicaciones .NET utilizando nuestro práctico documento de referencia. Con acceso rápido a funciones y ejemplos comunes para generar y editar PDF en C# y VB.NET, esta herramienta para compartir le ayuda a ahorrar tiempo y esfuerzo al empezar a utilizar IronPDF y los requisitos comunes de PDF en su proyecto.

Guarde la chuleta

Más documentación

Lea la Referencia de la API de IronPDF, que presenta exhaustivamente los detalles de todas las características de IronPDF, además de los espacios de nombres, clases, métodos, campos y enums.

Documentación de referencia de la API