ByteDev.Encoding 2.0.0

.NET Standard 2.0
dotnet add package ByteDev.Encoding --version 2.0.0
NuGet\Install-Package ByteDev.Encoding -Version 2.0.0
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="ByteDev.Encoding" Version="2.0.0" />
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add ByteDev.Encoding --version 2.0.0
#r "nuget: ByteDev.Encoding, 2.0.0"
#r directive can be used in F# Interactive, C# scripting and .NET Interactive. Copy this into the interactive tool or source code of the script to reference the package.
// Install ByteDev.Encoding as a Cake Addin
#addin nuget:?package=ByteDev.Encoding&version=2.0.0

// Install ByteDev.Encoding as a Cake Tool
#tool nuget:?package=ByteDev.Encoding&version=2.0.0

ByteDev.Encoding

Library of encoding/decoding related functionality for Hexadecimal, Base64 and Base32.

Installation

ByteDev.Encoding has been written as a .NET Standard 2.0 library, so you can consume it from a .NET Core or .NET Framework 4.6.1 (or greater) application.

ByteDev.Encoding is hosted as a package on nuget.org. To install from the Package Manager Console in Visual Studio run:

Install-Package ByteDev.Encoding

Further details can be found on the nuget page.

Release Notes

Releases follow semantic versioning.

Full details of the release notes can be viewed on GitHub.

Usage

The main library classes include:

  • Base32Encoder
  • Base64Encoder
  • HexEncoder
  • Serializer
  • EncoderFactory

String extension methods:

  • IsBase32
  • IsBase64
  • IsHex

Char extension methods:

  • IsBase32
  • IsBase64
  • IsHex

Base32Encoder

Base32Encoder provides a way to encode to base32 strings and decode back again.

IEncoder encoder = new Base32Encoder();

string base32 = encoder.Encode("John");
// base32 == "JJXWQ3Q="

bool isBase32 = base32.IsBase32();
// isBase32 == true

string text = encoder.Decode(base32);
// text == "John"

Base64Encoder

Base64Encoder provides a way to encode to base64 strings and decode back again.

IEncoder encoder = new Base64Encoder();

string base64 = encoder.Encode("John");
// base64 == "Sm9obg=="

bool isBase64 = base64.IsBase64();
// isBase64 == true

string text = encoder.Decode(base64);
// text == "John"

HexEncoder

HexEncoder provides a way to encode to hexadecimal strings and decode back again.

IEncoder encoder = new HexEncoder('='); // optional delimiter arg

string hex = encoder.Encode("John");
// hex == "4A=6F=68=6E"

bool isHex = hex.IsHex('=');
// isHex == true

string text = encoder.Decode(hex);
// text == "John"

Serializer

The Serializer class provides a way to serialize/deserialize objects based on the provided IEncoder implementation (Base32, Base64 or Hex).

// Entity to serialize
[Serializable]
public class Person
{
    public string Name { get; set; }
}

// ...

var person = new Person { Name = "John Smith" }
// Setup serializer
IEncoder encoder = new Base64Encoder();

ISerializer serializer = new Serializer(encoder);
// Serialize
string base64 = serializer.Serialize(person);
// Deserialize
Person person = serializer.Deserialize<Person>(base64);

EncoderFactory

The EncoderFactory provides a convenient way to create a type of encoder based on the EncodingType.

IEncoderFactory factory = new EncoderFactory();

IEncoder base64Encoder = factory.Create(EncodingType.Base64);
Product Versions
.NET net5.0 net5.0-windows net6.0 net6.0-android net6.0-ios net6.0-maccatalyst net6.0-macos net6.0-tvos net6.0-windows net7.0 net7.0-android net7.0-ios net7.0-maccatalyst net7.0-macos net7.0-tvos net7.0-windows
.NET Core netcoreapp2.0 netcoreapp2.1 netcoreapp2.2 netcoreapp3.0 netcoreapp3.1
.NET Standard netstandard2.0 netstandard2.1
.NET Framework net461 net462 net463 net47 net471 net472 net48 net481
MonoAndroid monoandroid
MonoMac monomac
MonoTouch monotouch
Tizen tizen40 tizen60
Xamarin.iOS xamarinios
Xamarin.Mac xamarinmac
Xamarin.TVOS xamarintvos
Xamarin.WatchOS xamarinwatchos
Compatible target framework(s)
Additional computed target framework(s)
Learn more about Target Frameworks and .NET Standard.
  • .NETStandard 2.0

    • No dependencies.

NuGet packages (2)

Showing the top 2 NuGet packages that depend on ByteDev.Encoding:

Package Downloads
ByteDev.Crypto

Provides simple cryptographic related classes for hashing/verifying data, encrypting/decrypting data and creating random data in .NET.

Casper.Net.Sdk

C# SDK For the Casper Network

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last updated
2.0.0 7,059 5/31/2021
1.1.0 778 12/11/2020
1.0.1 324 10/6/2020
1.0.0 1,102 6/9/2020