Codificar imágenes en línea

¡Codifique imágenes con Aspose.SVG for .NET API en tiempo real! Cargue una imagen del sistema de archivos local e inmediatamente obtendrá el resultado como URI de datos, fuente de imagen Base64 y fuente de fondo CSS Base64. Se admiten JPG, JPEG, SVG, PJP, PJPEG, PNG, BMP, XBM, GIF, TIFF, ICO, IFIF, WEBP y otros formatos de imagen.

Acerca del esquema URI

URI de datos es un método para incrustar imágenes y otros archivos en páginas web como una cadena de texto basada en la codificación Base64. El esquema de URI de datos le permite incluir cualquier dato binario en documentos HTML, CSS, JSON o SVG. Por ejemplo, puede incrustar imágenes en una página web como si se hubieran cargado desde un recurso externo, pero en lugar de especificar la URL del archivo, inserte el contenido codificado en Base64 de la imagen. El esquema de URI de datos se definió en RFC 2397 y, a partir de 2022, es totalmente compatible con la mayoría de los principales navegadores. La principal ventaja del uso de URI de datos es la aceleración de la carga de la página porque el navegador no necesita realizar una solicitud web adicional para recuperar el archivo, ya que la imagen ya está incrustada en el documento HTML.

La sintaxis del URI de datos es la siguiente: data:[<mime type>][;charset=<charset>][;base64],<encoded data>.

Debido a que el tamaño de los datos codificados en Base64 aumenta en un 33 %, se recomienda usar URI de datos solo para imágenes pequeñas. Las imágenes grandes de Base64 producen una gran cantidad de código en el HTML, lo que resulta en una pérdida de beneficios de rendimiento. Si necesita convertir la imagen a Base64 y usar una cadena codificada para incrustar en un archivo de texto, aprenda primero todos los pros y los contras.


Cómo convertir una imagen a Base64 en C#

Para convertir una imagen a una cadena Base64, usamos Aspose.SVG for .NET API, que es una API rica en funciones, potente y fácil de usar. utilice la API de manipulación de documentos para la plataforma C#. Consideramos el ejemplo de la codificación de imagen PNG a Base64 e incrustación de cadena Base64 como URI de datos en un documento SVG. Estas operaciones se pueden hacer con unas pocas líneas de código:


Código C# para convertir la imagen en una cadena Base64 e incrustarla en un archivo SVG

    // Open a binary file – raster image
    var bytes = File.ReadAllBytes(@"image.png");
    // Initialize an SVGDocument object
    var document = new SVGDocument();
    // Create an image element
    var img = (SVGImageElement)document.CreateElementNS("http://www.w3.org/2000/svg", "image");
    // Convert PNG image to Base64
    img.Href.BaseVal = "data:image/png;charset=utf-8;base64," + Convert.ToBase64String(bytes);
    // Add the image element into the SVG document
    document.RootElement.AppendChild(img);
    // Save the SVG document
    document.Save(@"image-base64.svg");



Pasos para convertir una imagen a Base64 en C#

  1. Abra una imagen para convertir. Utilice el método ReadAllBytes(path) para abrir la imagen PNG y leer el contenido del archivo en una matriz de bytes.
  2. Inicialice una nueva instancia de la clase SVGDocument.
  3. Use el método CreateElementNS(namespaceURI,qualifiedName) de la clase SVGDocument para crear un instancia de imagen El namespaceURI establece la referencia a la especificación W3C SVG. El qualifiedName debe contener el nombre de la etiqueta de cadena del elemento de la imagen.
  4. Convierta la imagen a Base64. Llame al método ToBase64String(bytes) para convertir una matriz de enteros de 8 bits en su representación de cadena equivalente codificada en dígitos base64.
  5. Agregue el elemento de imagen al documento SVG usando el método AppendChild(node).
  6. Llame al método Save(path) para guardar el documento SVG.

Pros y contras de URI de datos

El URI de datos nos brinda una forma inteligente de incrustar imágenes en una página web. Los esquemas de URI se pueden utilizar de muchas maneras. Pero en cualquier caso, hay pros y contras.

Pros:

  • Acelerar la carga de la página. El navegador no necesita realizar una solicitud web adicional para recuperar el archivo porque la imagen ya está incrustada en el documento HTML.
  • Mejora del rendimiento. El navegador requiere menos tiempo de CPU.
  • Las páginas web se vuelven independientes de los archivos externos, lo que facilita compartirlas incluso sin conexión.

Desventajas:

  • El tamaño de los datos codificados en Base64 es 1/3 más grande que la imagen binaria.
  • El navegador no almacena en caché las imágenes codificadas y se descargarán cada vez que se visite dicha página.
  • Las imágenes codificadas son difíciles de editar porque primero se debe decodificar la cadena Base64.
  • Google nunca indexará una imagen Base64 porque no aparece en los resultados de búsqueda de imágenes.

Codificadores Base64 en línea

Aspose.SVG ofrece aplicaciones en línea gratuitas para codificar y decodificar datos binarios:

  • Codificadores Base64 son un conjunto de herramientas que le permiten codificar datos binarios en varios formatos de salida: Plain Base64, JSON, XML, URI o CSS.
  • Image Base64 Decoder convierte un URI de datos que contiene una cadena Base64 en una imagen pegando una cadena URI en el control de entrada.

Nuestras aplicaciones basadas en navegador funcionan en todas las plataformas, incluidas Windows, Linux, Mac OS, Android e iOS. No se requiere registro, complemento o instalación de software para usted. ¡Comience a usar nuestras herramientas de codificación/descodificación Base64 en línea de manera segura, segura y fácil!

Ejemplos de uso de codificación Base64

Código SVG para incrustar la imagen Base64 en un documento SVG

<svg xmlns="http://www.w3.org/2000/svg">
	<image href="data:image/png;charset=utf-8;base64,iVBORw0KGgoAAAANSUhEUgAAACAAAAAg..." alt="Red circle"/>
</svg>

Código HTML para incrustar imagen Base64

<body>
    <div>
        <img src="..." alt="Red circle">
    </div>
</body>

Código CSS para incrustar la imagen Base64 como imagen de fondo

.class {
    background-image: url('...');
}

Código XML para incrustar la imagen Base64 en un documento XML

<?xml version="1.0" encoding="UTF-8"?>
<root>
<image mime = "image/png">iVBORw0KGgoAAAANSUhEUgAAACAAAAAg...</image>
</root>

Código JSON para incrustar la imagen Base64 en el documento JSON

{
  "image": {
    "mime": "image/png",
    "data": "iVBORw0KGgoAAAANSUhEUgAAACAAAAAg..."
  }
}



Preguntas más frecuentes

1. ¿Cómo puedo convertir Image a Base64?

Aspose.SVG le permite convertir Image a una cadena Base64 de cualquier manera, en línea o mediante programación. Por ejemplo, puede codificar Image en tiempo real usando el Codificador Image en línea que convierte tus archivos rápidamente y con alta calidad. ¡Cargue, codifique Image y obtenga el resultado en unos segundos! Por otro lado, puede usar Aspose.SVG for .NET API para convertir Image a Base64 mediante programación.

2. ¿Por qué se necesita la codificación Base64?

Históricamente, muchos formatos de almacenamiento y transferencia de datos utilizan texto en lugar de código binario (HTML, XML, correo electrónico, etc.). ¿Qué sucede si el formato de transferencia de datos está basado en texto, pero necesita transferir los datos binarios? Aquí es donde entra en juego la codificación Base64. Para evitar la mala interpretación de los símbolos binarios al enviar datos a través de Internet, es necesario codificarlos en caracteres. Algunas aplicaciones típicas de la codificación Base64: esquemas URI de datos para imágenes (CSS, HTML, JavaScript); transferir imágenes y otros datos binarios a XML; almacenar imágenes en una base de datos; incluir imágenes en los mensajes de correo electrónico.

3. ¿Qué navegadores admiten URI de datos?

Data URI es la forma más rápida y sencilla de incrustar imágenes y otros archivos en sus páginas web. El URI de datos es compatible con los principales navegadores modernos: Chrome, Firefox, Safari, Edge, Opera e IE8+.

4. ¿Qué es la codificación Base64?

Base64 es un esquema de codificación de binario a texto que representa datos binarios en un formato de cadena ASCII. La codificación Base64 se usa comúnmente cuando es necesario codificar información binaria que debe almacenarse y transferirse a través de medios diseñados para trabajar con datos de texto.

Comience con API Aspose.SVG for .NET

Si está interesado en desarrollar gráficos vectoriales escalables y sus aplicaciones, instale nuestro Aspose.SVG for .NET API flexible y de alta velocidad con un potente conjunto de interfaces para C# y otros lenguajes de programación .NET.
Instale desde la línea de comando como nuget install Aspose.SVG o mediante la consola del administrador de paquetes de Visual Studio con Install-Package Aspose.SVG. Alternativamente, obtenga el instalador MSI sin conexión o archivos DLL en un archivo ZIP desde downloads. Aspose.SVG for .NET API es una biblioteca independiente y no depende de ningún software para el procesamiento de documentos SVG.
Para obtener más detalles sobre la instalación de la biblioteca C# y los requisitos del sistema, consulte la Documentación de Aspose.SVG.

Otros codificadores Base64 compatibles

Puede convertir la imagen en una cadena Base64. Se admiten los formatos JPG, PNG, BMP, GIF, TIFF, ICO y SVG:

JPG to Base64 (JPEG Image)
PNG to Base64 (Portable Network Graphics)
BMP to Base64 (Bitmap Image)
SVG to Base64 (Scalable Vector Graphics)
TIFF to Base64 (Tagged Image Format)
GIF TO Base64 (Graphical Interchange Format)
ICO to Base64 (Computer Icons Format)
Image to Base64 (Binary Image)