The library contains the static DataUrl
class that supports the "data" URL scheme (RFC 2397), which allows to embed data in a URI. The DataUrl
class allows
- building "data" URL strings from files, byte arrays or text,
- parsing "data" URL strings as
DataUrlInfo
structs in order to examine their content without having to allocate a lot of sub-strings, and to enable the comparison of "data" URLs for equality, - retrieving the embedded data from "data" URL strings,
- retrieving an appropriate file type extension for the embedded data.
The library is designed to support performance and small heap allocation.
Creating and parsing a "data" URL:
using FolkerKinzel.DataUrls;
using FolkerKinzel.DataUrls.Extensions;
using System.Diagnostics;
namespace Examples;
public static class DataUrlExample
{
public static void Example()
{
// Creates a temporary JPG file for testing.
string photoFilePath = CreatePhotoFile();
// Creates a "data" URL string from the file.
// The MIME type comes from the file type extension
// (if not provided as argument):
string dataUrl = DataUrl.FromFile(photoFilePath);
// (The photo file is no longer needed.)
File.Delete(photoFilePath);
// Uncomment this to show the content of the
// "data" URL in the Microsoft Edge browser.
// (Make shure you have this browser installed.):
// ShowPictureInMicrosoftEdge(dataUrl);
Console.WriteLine(dataUrl);
Console.WriteLine();
Console.WriteLine("Is \"data\" URL: {0}", dataUrl.IsDataUrl());
Console.WriteLine();
// Parse the content of the "data" URL:
_ = DataUrl.TryParse(dataUrl, out DataUrlInfo info);
Console.WriteLine("Data Type: {0}", info.DataType);
Console.WriteLine("MIME Type: {0}", info.MimeType);
Console.WriteLine("File Type Ext.: {0}", info.GetFileTypeExtension());
Console.WriteLine("Data Encoding: {0}", info.Encoding);
Console.WriteLine();
if (info.TryGetData(out EmbeddedData data))
{
// EmbeddedData is a union that contains either a
// byte array or a string.
Console.WriteLine(data);
}
}
/// <summary>
/// Creates a temporary photo file. The data comes from a given "data" URL.
/// </summary>
/// <returns>The file path.</returns>
private static string CreatePhotoFile()
{
const string url = "";
string path = "";
// Tries to get the embedded data as Byte array
// (and an appropriate file type extension too):
if (DataUrl.TryGetBytes(url,
out byte[]? bytes,
out string? fileTypeExtension) && bytes.Length > 0)
{
path = Path.Combine(
Directory.GetCurrentDirectory(), $"{Guid.NewGuid()}{fileTypeExtension}");
File.WriteAllBytes(path, bytes);
}
return path;
}
/// <summary>
/// Displays the content of a "data" URL in the Edge browser.
/// </summary>
/// <param name="dataUrl">The "data" URL.</param>
private static void ShowPictureInMicrosoftEdge(string dataUrl)
{
var process = new Process();
process.StartInfo.UseShellExecute = true;
process.StartInfo.FileName = "msedge";
process.StartInfo.Arguments = dataUrl;
_ = process.Start();
}
}
/*
Console Output:

Is "data" URL: True
Data Type: Binary
MIME Type: image/jpeg
File Type Ext.: .jpg
Data Encoding: Base64
System.Byte[]: 2472 Bytes
*/