NET API
HSM Dinamo
Loading...
Looking for...
No entries found
enc_dec.cs

Example of symmetric encryption and decryption using HSM.

See Note on examples.
using System;
using System.Collections.Generic;
using System.Text;
using Dinamo.Hsm;
namespace TesteNF
{
class Program
{
static void Main(string[] args)
{
DinamoClient dinamo = new DinamoClient();
dinamo.Connect( "10.0.62.16",
"master",
"12345678" );
//Nome da chave AES 256 dentro do HSM
string keyId = "aes256";
byte[] iv = new byte[DinamoApi.AES_IV_LEN]{ 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 };
//Dado original
byte[] originalData = Encoding.ASCII.GetBytes("asdfasdfasdfasdfasdfas");
//Adiciona o tamanho do bloco para caber um possivel padding.
//O tamanho do IV eh igual ao tamanho do bloco.
byte[] dataToEncrypt = new byte[originalData.Length + DinamoApi.AES_IV_LEN];
//Bloco que sera encriptado. Estes dados serao sobrescritos.
Array.Copy(originalData, dataToEncrypt, originalData.Length);
int dataToEncryptLen = originalData.Length;
dinamo.Encrypt( keyId,
IntPtr.Zero,
true,
iv,
DinamoClient.PADDING_TYPE.PKCS5_PADDING,
dataToEncrypt,
ref dataToEncryptLen,
dataToEncrypt.Length);
dinamo.Decrypt( keyId,
IntPtr.Zero,
true,
iv,
DinamoClient.PADDING_TYPE.PKCS5_PADDING,
dataToEncrypt,
ref dataToEncryptLen );
Console.Out.WriteLine("Dado decriptado:\n {0}", System.Text.Encoding.Default.GetString(dataToEncrypt));
Console.In.ReadLine();
}
}
}
Classe de baixo nível para acesso ao HSM. Para utilizar essa classe é necessário o entendimento mais ...
Definição DinamoApi.cs:15
const Int32 AES_IV_LEN
Definição DinamoApi.cs:903
Classe de API para acesso às funcionalidades do HSM Dinamo. Nessa classe é possível programar utiliza...
Definição DinamoClient.cs:93
MODE_TYPE
Definição DinamoClient.cs:430
PADDING_TYPE
Definição DinamoClient.cs:437
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 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
Namespace que denota um conjunto de funções para acesso ao HSM Dinamo e suas respectivas exceptions.
Definição DinamoClient.cs:12