https://github.com/folkerkinzel/dataurls
.NET library that supports working with "data" URLs (RFC 2397)
https://github.com/folkerkinzel/dataurls
csharp data-url dotnet rfc-2397
Last synced: 3 months ago
JSON representation
.NET library that supports working with "data" URLs (RFC 2397)
- Host: GitHub
- URL: https://github.com/folkerkinzel/dataurls
- Owner: FolkerKinzel
- License: mit
- Created: 2024-03-10T16:09:16.000Z (about 1 year ago)
- Default Branch: master
- Last Pushed: 2024-12-24T16:05:49.000Z (5 months ago)
- Last Synced: 2025-01-05T09:13:19.048Z (5 months ago)
- Topics: csharp, data-url, dotnet, rfc-2397
- Language: C#
- Homepage:
- Size: 12.6 MB
- Stars: 3
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
- Security: SECURITY.md
Awesome Lists containing this project
README
# FolkerKinzel.DataUrls
[](https://www.nuget.org/packages/FolkerKinzel.DataUrls/)
[](https://github.com/FolkerKinzel/DataUrls/blob/master/LICENSE)
[](https://stand-with-ukraine.pp.ua)## .NET library that supports working with "data" URLs (RFC 2397)
[Project Reference](https://folkerkinzel.github.io/DataUrls/reference/)
The library contains the static `DataUrl` class that supports the "data" URL scheme ([RFC 2397](https://datatracker.ietf.org/doc/html/rfc2397)), 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.
[Version History](https://github.com/FolkerKinzel/DataUrls/releases)
### Example:
Creating and parsing a "data" URL:
```csharp
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);
}
}///
/// Creates a temporary photo file. The data comes from a given "data" URL.
///
/// The file path.
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;
}///
/// Displays the content of a "data" URL in the Edge browser.
///
/// The "data" URL.
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: Base64System.Byte[]: 2472 Bytes
*/
```