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 System.Diagnostics;
using FolkerKinzel.DataUrls;
using OneOf;
namespace Examples;
public static class DataUrlExample
{
public static void Example()
{
string fotoFilePath = CreatePhotoFile();
string dataUrl = DataUrl.FromFile(fotoFilePath);
File.Delete(fotoFilePath);
// 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();
// Parse the content of the "data" URL:
_ = DataUrl.TryParse(dataUrl, out DataUrlInfo info);
Console.WriteLine($"Contains Bytes: {info.ContainsEmbeddedBytes}");
Console.WriteLine($"Contains Text: {info.ContainsEmbeddedText}");
Console.WriteLine($"MIME Type: {info.MimeType}");
Console.WriteLine($"File Type Ext.: {info.GetFileTypeExtension()}");
Console.WriteLine($"Data Encoding: {info.DataEncoding}");
if (info.TryGetEmbeddedBytes(out byte[]? bytes))
{
Console.WriteLine($"Data Length: {bytes.Length} Bytes");
}
}
private static string CreatePhotoFile()
{
string url = "";
string path = "";
if (DataUrl.TryGetEmbeddedData(url, out OneOf<string, byte[]> data, out string? fileTypeExtension)
&& data.Value is byte[] bytes)
{
path = Path.Combine(Directory.GetCurrentDirectory(), $"{Guid.NewGuid()}{fileTypeExtension}");
File.WriteAllBytes(path, bytes);
}
return path;
}
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:

Contains Bytes: True
Contains Text: False
MIME Type: image/jpeg
File Type Ext.: .jpg
Data Encoding: Base64
Data Length: 2472 Bytes
*/