Convertir HTML de un archivo ZIP a PDF – ejemplo de C#

En este artículo, creamos un controlador de mensajes personalizado para realizar una tarea específica: convertir HTML de un archivo ZIP a PDF.

Hay muchas razones por las que necesitarías convertir HTML de un archivo ZIP a formato PDF. El PDF tiene muchas ventajas que otros archivos no tienen. Por ejemplo, muchos programas y aplicaciones admiten documentos PDF; la mayoría de los navegadores web, como Chrome y Firefox, pueden mostrar un PDF. Los archivos PDF están optimizados para imprimir; son ideales para crear copias físicas de sus documentos. PDF admite muchos algoritmos de compresión. Puede configurar los ajustes de seguridad para su archivo PDF, etc.

Crear un controlador de mensajes personalizado

Aspose.HTML for .NET ofrece funcionalidad para la creación de controladores de mensajes personalizados. Diseñemos un controlador personalizado que podamos usar para trabajar con archivos ZIP. Tome los siguientes pasos:

  1. Utilice el espacio de nombres necesario, que es Aspose.Html.Net. Este espacio de nombres se presenta mediante clases e interfaces que son responsables de facilitar el procesamiento de la red.

  2. Para crear un controlador de mensajes personalizado, debe definir su propia clase que se derivará de la clase MessageHandler. La clase MessageHandler representa un tipo base para controladores de mensajes. Es necesario heredar de IDisposable para proporcionar un mecanismo para la liberación determinista de recursos no administrados.

1using Aspose.Html.Net;
2...
3
4	class ZipArchiveMessageHandler : MessageHandler, IDisposable
5	{
6	}

Entonces, ha definido su propia clase ZipArchiveMessageHandler, ahora necesita realizar algunas operaciones dentro de ella. 3. Inicialice una instancia de la clase ZipArchiveMessageHandler y defina una propiedad Filter para ella.

  1. Anule el método Invoke() de la clase MessageHandler para implementar el comportamiento personalizado del controlador de mensajes.
 1// Implement ZipArchiveMessageHandler in C#
 2
 3// This message handler prints a message about start and finish processing request
 4class ZipArchiveMessageHandler : MessageHandler, IDisposable
 5{
 6    private string filePath;
 7    private Archive archive;
 8
 9    // Initialize an instance of the ZipArchiveMessageHandler class
10    public ZipArchiveMessageHandler(string path)
11    {
12        this.filePath = path;
13        Filters.Add(new ProtocolMessageFilter("zip"));
14    }
15
16    // Override the Invoke() method
17    public override void Invoke(INetworkOperationContext context)
18    {
19        // Call the GetFile() method that defines the logic in the Invoke() method
20        byte[] buff = GetFile(context.Request.RequestUri.Pathname.TrimStart('/'));
21        if (buff != null)
22        {
23            // Checking: if a resource is found in the archive, then return it as a Response
24            context.Response = new ResponseMessage(HttpStatusCode.OK)
25            {
26                Content = new ByteArrayContent(buff)
27            };
28            context.Response.Headers.ContentType.MediaType = MimeType.FromFileExtension(context.Request.RequestUri.Pathname);
29        }
30        else
31        {
32            context.Response = new ResponseMessage(HttpStatusCode.NotFound);
33        }
34
35        // Call the next message handler
36        Next(context);
37    }
38
39
40    byte[] GetFile(string path)
41    {
42        path = path.Replace(@"\", @"/");
43        ArchiveEntry result = GetArchive().Entries.FirstOrDefault(x => path == x.Name);
44        if (result != null)
45        {
46            using (Stream fs = result.Open())
47            using (MemoryStream ms = new MemoryStream())
48            {
49                fs.CopyTo(ms);
50                return ms.ToArray();
51            }
52        }
53        return null;
54    }
55
56    Archive GetArchive()
57    {
58        return archive ??= new Archive(filePath);
59    }
60
61    public void Dispose()
62    {
63        archive?.Dispose();
64    }
65}

Echemos un vistazo más de cerca a este fragmento de código:

Agregar ZipArchiveMessageHandler en la canalización

Ahora deberá agregar ZipArchiveMessageHandler en el proceso. Utilice el método Add() que toma un objeto zip como parámetro y agrega ZipArchiveMessageHandler al final de la colección de controladores de mensajes.

La propiedad INetworkService.MessageHandlers obtiene una lista de instancias de MessageHandler que se invocarán cuando se ejecuta RequestMessage.

 1// Convert HTML from a ZIP archive to PDF using C#
 2
 3// Add this line before you try to use the 'IBM437' encoding
 4System.Text.Encoding.RegisterProvider(System.Text.CodePagesEncodingProvider.Instance);
 5
 6// Prepare path to a source zip file
 7string documentPath = Path.Combine(DataDir, "test.zip");
 8
 9// Prepare path for converted file saving
10string savePath = Path.Combine(OutputDir, "zip-to-pdf.pdf");
11
12// Create an instance of ZipArchiveMessageHandler
13using ZipArchiveMessageHandler zip = new ZipArchiveMessageHandler(documentPath);
14
15// Create an instance of the Configuration class
16using Configuration configuration = new Configuration();
17
18// Add ZipArchiveMessageHandler to the chain of existing message handlers
19configuration
20    .GetService<INetworkService>()
21    .MessageHandlers.Add(zip);
22
23// Initialize an HTML document with specified configuration
24using HTMLDocument document = new HTMLDocument("zip:///test.html", configuration);
25
26// Create the PDF Device  
27using PdfDevice device = new PdfDevice(savePath);
28
29// Render ZIP to PDF
30document.RenderTo(device);

En el ejemplo, el archivo ZIP (test.zip) tiene el documento HTML (test.html) en el que todos los recursos relacionados tienen rutas relativas al documento HTML.

Nota: El constructor HTMLDocument(address, configuration) toma la ruta absoluta al archivo ZIP. Pero todos los recursos relacionados tienen rutas relativas en el documento HTML y en el código del ejemplo.

Lea el artículo Convserters de ajuste fino para obtener más información sobre cómo convertir HTML a PDF usando el método Renderto(device).

Aspose.HTML proporciona un Convertidor de ZIP a PDF en línea gratuito que le permite convertir HTML de forma rápida, sencilla y clara desde un archivo ZIP a PDF. Cargue, convierta archivos y obtenga resultados en segundos. No se requiere software adicional. ¡Pruebe nuestro robusto convertidor gratis ahora!

Texto “Convertidor de ZIP a PDF”

Subscribe to Aspose Product Updates

Get monthly newsletters & offers directly delivered to your mailbox.