Blake2b.Net
1.0.0
dotnet add package Blake2b.Net --version 1.0.0
NuGet\Install-Package Blake2b.Net -Version 1.0.0
<PackageReference Include="Blake2b.Net" Version="1.0.0" />
paket add Blake2b.Net --version 1.0.0
#r "nuget: Blake2b.Net, 1.0.0"
// Install Blake2b.Net as a Cake Addin #addin nuget:?package=Blake2b.Net&version=1.0.0 // Install Blake2b.Net as a Cake Tool #tool nuget:?package=Blake2b.Net&version=1.0.0
Blake2b.Net
Blake2b.Net provides an implementation of the cryptographic hash and MAC functions of the BLAKE2b algorithm, optimized for SIMD hardware instructions and PinnedMemory support.
Features
- Supports cryptographic hash generation using BLAKE2b.
- MAC (Message Authentication Code) functionality with key and salt.
- Optimized for SIMD instructions to ensure fast performance on supported hardware.
- Secure key and buffer management with PinnedMemory to avoid sensitive data leaks.
Installation
You can install the package via NuGet:
.NET CLI
dotnet add package Blake2b.Net
Package Manager
Install-Package Blake2b.Net
NuGet Website
You can also search for and install the package via the NuGet UI or from the following link: Blake2b.Net on NuGet
Usage Examples
Hashing Example:
var digest = new Blake2b();
using var exampleHash = new PinnedMemory<byte>(new byte[digest.GetLength()]);
digest.UpdateBlock(new PinnedMemory<byte>(new byte[] {63, 61, 77, 20, 63, 61, 77, 20, 63, 61, 77}, false), 0, 11);
digest.DoFinal(exampleHash, 0);
MAC Example:
var digest = new Blake2bMac(new PinnedMemory<byte>(new byte[] {63, 61, 77, 20, 63, 61, 77}, false));
using var exampleHash = new PinnedMemory<byte>(new byte[digest.GetLength()]);
digest.UpdateBlock(new PinnedMemory<byte>(new byte[] {63, 61, 77, 20, 63, 61, 77, 20, 63, 61, 77}, false), 0, 11);
digest.DoFinal(exampleHash, 0);
API Documentation
Constructors
Blake2b(int digestSize = 512)
- Initializes a new instance of the
Blake2b
class with the specified digest size. - Supported digest sizes: 160, 256, 384, 512 bits.
- Default size: 512 bits.
Blake2bMac(PinnedMemory<byte> key)
- Initializes a new instance of the
Blake2bMac
class with the specified key for MAC generation. - The key should be provided in the form of a
PinnedMemory<byte>
object.
Blake2bMac(PinnedMemory<byte> key, byte[] salt, int digestSize = 512)
- Initializes a new instance of the
Blake2bMac
class with the specified key, salt, and digest size. - Supported digest sizes: 160, 256, 384, 512 bits.
- Default size: 512 bits.
- The salt must be 16 bytes long.
Methods
void Update(byte b)
- Updates the message digest with a single byte.
void UpdateBlock(PinnedMemory<byte> message, int offset, int len)
- Updates the message digest with a pinned memory byte array.
void UpdateBlock(byte[] message, int offset, int len)
- Updates the message digest with a regular byte array.
void DoFinal(PinnedMemory<byte> output, int outOffset)
- Produces the final digest value and outputs it to the specified
PinnedMemory<byte>
buffer.
void Reset()
- Resets the digest to its initial state for further processing.
- The key and salt remain until the object is disposed.
void Dispose()
- Clears the key and salt, resets the digest to its initial state, and releases resources.
Performance Considerations
The BLAKE2b algorithm is optimized for modern SIMD instructions (such as AVX and SSE) to provide enhanced performance on supported hardware. This ensures that hashing and MAC operations are processed efficiently, even with large datasets.
Security Considerations
This library utilizes PinnedMemory
to ensure that sensitive data such as keys and message buffers are not moved by the garbage collector, reducing the risk of memory leaks. Ensure that you call Dispose()
on any PinnedMemory
object or classes that use it to securely clear and free memory after use.
License
This project is licensed under the MIT License - see the LICENSE file for details.
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net8.0 is compatible. net8.0-android was computed. net8.0-browser was computed. net8.0-ios was computed. net8.0-maccatalyst was computed. net8.0-macos was computed. net8.0-tvos was computed. net8.0-windows was computed. |
-
net8.0
- PinnedMemory (>= 2.0.0)
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.
Version | Downloads | Last updated |
---|---|---|
1.0.0 | 93 | 10/16/2024 |