Convertir HTML de un archivo ZIP a JPG – 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 JPG.
Puede descargar los ejemplos completos de C# y los archivos de datos desde GitHub.
Hay muchas razones por las que necesitarías convertir HTML de un archivo ZIP al formato JPG. Por ejemplo, si desea convertir un documento HTML (XHTML) que contiene recursos vinculados a JPG, debe empaquetar todos estos recursos junto con el documento en un único archivo ZIP y convertirlo a JPG. Aspose.HTML for .NET proporciona funcionalidad para crear controladores de mensajes personalizados para trabajar con archivos ZIP.
Crear un controlador de mensajes personalizado
Aspose.HTML for .NET ofrece funcionalidad para la creación de un controlador de mensajes personalizado. Diseñemos el controlador personalizado que podemos usar para trabajar con archivos ZIP. Tome los siguientes pasos:
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.
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.
1using Aspose.Html.Net;
2...
3
4 class ZipArchiveMessageHandler : MessageHandler
5 {
6 }
- Anule el método Invoke() de la clase MessageHandler para implementar el comportamiento personalizado del controlador de mensajes.
1// This message handler prints a message about start and finish processing request
2class ZipArchiveMessageHandler : MessageHandler, IDisposable
3{
4 private string filePath;
5 private Archive archive;
6
7 // Initialize an instance of the ZipArchiveMessageHandler class
8 public ZipArchiveMessageHandler(string path)
9 {
10 this.filePath = path;
11 Filters.Add(new ProtocolMessageFilter("zip"));
12 }
13
14 // Override the Invoke() method
15 public override void Invoke(INetworkOperationContext context)
16 {
17 // Call the GetFile() method that defines the logic in the Invoke() method
18 var buff = GetFile(context.Request.RequestUri.Pathname.TrimStart('/'));
19 if (buff != null)
20 {
21 // Checking: if a resource is found in the archive, then return it as a Response
22 context.Response = new ResponseMessage(HttpStatusCode.OK)
23 {
24 Content = new ByteArrayContent(buff)
25 };
26 context.Response.Headers.ContentType.MediaType = MimeType.FromFileExtension(context.Request.RequestUri.Pathname);
27 }
28 else
29 {
30 context.Response = new ResponseMessage(HttpStatusCode.NotFound);
31 }
32
33 // Call the next message handler
34 Next(context);
35 }
36
37
38 byte[] GetFile(string path)
39 {
40 path = path.Replace(@"\", @"/");
41 var result = GetArchive().Entries.FirstOrDefault(x => path == x.Name);
42 if (result != null)
43 {
44 using (var fs = result.Open())
45 using (MemoryStream ms = new MemoryStream())
46 {
47 fs.CopyTo(ms);
48 return ms.ToArray();
49 }
50 }
51 return null;
52 }
53
54 Archive GetArchive()
55 {
56 return archive ??= new Archive(filePath);
57 }
58
59 public void Dispose()
60 {
61 archive?.Dispose();
62 }
63}
Consideremos más de cerca el fragmento de código:
El ZipArchiveMessageHandler personalizado debe heredar de la clase MessageHandler base. Tiene dos variables: el archivo y la representación de cadena de la ruta al archivo. Es necesario heredar de IDisposable para proporcionar un mecanismo para la liberación determinista de recursos no administrados.
El controlador de mensajes tiene el concepto de filtrado. En este caso, se agrega un filtro de protocolo (esquema), este controlador de mensajes solo funcionará con el protocolo
"zip"
.El filtrado de mensajes por protocolo de recursos se implementa utilizando la clase ProtocolMessageFilter. El constructor ProtocolMessageFilter() inicializa una nueva instancia de la clase ProtocolMessageFilter. Toma como parámetro los protocolos
"zip"
.El método Invoke() implementa el comportamiento del controlador de mensajes. Se llama para cada controlador en la canalización y toma un “contexto” como parámetro. El método GetFile() define la lógica en el método Invoke(). Implementa la cadena de tareas, después de lo cual se llama al siguiente controlador Next(
context
).El método GetFile() realiza una búsqueda de datos como una matriz de bytes en un archivo zip basada en la Solicitud y los formularios de Respuesta.
context
proporciona información contextual para los servicios de red, la entidad de la operación pasa a través de él y se devuelve el resultado de la operación. En Aspose.HTML, elcontext
se realiza mediante la interfaz INetworkOperationContext que tiene dos propiedades (parámetros): Request y Response.
Agregue ZipArchiveMessageHandler a la canalización
El concepto clave del trabajo de los controladores de mensajes es encadenarlos, y ahora necesitaría agregar ZipArchiveMessageHandler en el proceso. El constructor Configuration() crea una instancia de la clase
Configuration. Una vez creada la configuración, se invocan los métodos GetService<INetworkService>() y MessageHandlers.Add(). El método Add() toma un objeto zip
como parámetro y agrega ZipArchiveMessageHandler al final de la colección de controladores de mensajes.
1// Add this line before you try to use the 'IBM437' encoding
2System.Text.Encoding.RegisterProvider(System.Text.CodePagesEncodingProvider.Instance);
3
4// Prepare path to a source zip file
5string documentPath = Path.Combine(DataDir, "test.zip");
6
7// Prepare path for converted file saving
8string savePath = Path.Combine(OutputDir, "zip-to-jpg.jpg");
9
10// Create an instance of ZipArchiveMessageHandler
11using var zip = new ZipArchiveMessageHandler(documentPath);
12
13// Create an instance of the Configuration class
14using var configuration = new Configuration();
15
16// Add ZipArchiveMessageHandler to the chain of existing message handlers
17configuration
18 .GetService<INetworkService>()
19 .MessageHandlers.Add(zip);
20
21// Initialize an HTML document with specified configuration
22using var document = new HTMLDocument("zip:///test.html", configuration);
23
24// Create an instance of Rendering Options
25var options = new ImageRenderingOptions()
26{
27 Format = ImageFormat.Jpeg
28};
29
30// Create an instance of Image Device
31using var device = new ImageDevice(options, savePath);
32
33// Render ZIP to JPG
34document.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.
Para obtener más información sobre cómo convertir HTML a JPG usando el método
Renderto(device
), lea el artículo
Ajuste de convertidores.
Puede descargar los ejemplos completos de C# y los archivos de datos desde GitHub.