Important
This repository is no longer maintained. Use FolkerKinzel.DataUrls instead!
Project Reference and Release Notes
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.Uris;
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
*/