Exemplo de encriptação e decriptação RSA direta.
using System;
using System.IO;
namespace RSAEncDec
{
class Program
{
static void Main(string[] args)
{
string address = "127.0.0.1";
string user = "master";
string pass = "12345678";
string keyId = "key_id";
true);
byte[] data = { 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07, 0x08 };
byte[] buffer = new byte[256];
data.CopyTo(buffer, 0);
Console.WriteLine("Dados entrada(len {0}): {1}", data.Length,
BitConverter.ToString(data));
byte[] pubKeyData = hsm.
ExportKey(keyHandle, IntPtr.Zero,
string pubKeyId = "rsa2048_pub";
IntPtr pubKeyHandle = hsm.
ImportKey(pubKeyId, IntPtr.Zero,
pubKeyData,
int outDataLen = data.Length;
Console.WriteLine("OutDataLen: {0}", outDataLen);
hsm.
Encrypt(pubKeyHandle, IntPtr.Zero,
true, 0,
null,
ref outDataLen, buffer.Length);
Console.WriteLine("Dados encriptados (len {0}): {1}", outDataLen,
BitConverter.ToString(buffer));
outDataLen = buffer.Length;
hsm.
Decrypt(keyHandle, IntPtr.Zero,
true, 0,
null,
ref outDataLen);
Console.WriteLine("Dados decriptados (len {0}): {1}", outDataLen,
BitConverter.ToString(buffer));
}
}
}
Classe de API para acesso às funcionalidades do HSM Dinamo. Nessa classe é possível programar utiliza...
Definição DinamoClient.cs:93
KEY_ALG
Definição DinamoClient.cs:227
MODE_TYPE
Definição DinamoClient.cs:430
PADDING_TYPE
Definição DinamoClient.cs:437
BLOB_TYPE
Definição DinamoClient.cs:449
void Encrypt(IntPtr hKey, bool Final, byte[] byData, ref int DataLen, int BufferLen)
Encrypt blocos ou arquivos passando a referencia da chave. Utiliza o mode/padding default,...
Definição DinamoClient.cs:3163
void Decrypt(string strKeyId, IntPtr hHash, bool Final, byte[] byData, ref int DataLen)
Decripta um hash, dado geral ou um arquivo.
Definição DinamoClient.cs:3504
void DestroyKey(IntPtr hKey)
Libera handle de chave.
Definição DinamoClient.cs:1953
byte[] ExportKey(IntPtr hKey, IntPtr hKeyEncryptionKey, BLOB_TYPE BlobType)
Definição DinamoClient.cs:2648
IntPtr ImportKey(string KeyId, IntPtr hKeyEncryptionKey, byte[] byKeyBlob, BLOB_TYPE BlobType, KEY_ALG AlgId)
Definição DinamoClient.cs:2668
IntPtr GenerateKey(string KeyId, DinamoClient.KEY_ALG Alg, bool Exportable)
Gera uma chave permanente no HSM.
Definição DinamoClient.cs:1891
void RemoveObject(string ObjectId)
Remove um objeto do HSM.
Definição DinamoClient.cs:2397
void Connect(string User, string Password)
Estabelece uma conexão cifrada com o HSM utilizando as configurações de load balance.
Definição DinamoClient.cs:562
void Disconnect(bool flagClose)
Encerra a conexão com o HSM.
Definição DinamoClient.cs:814
Namespace que denota um conjunto de funções para acesso ao HSM Dinamo e suas respectivas exceptions.
Definição DinamoClient.cs:12