Ver Mensaje Individual
  #1  
Antiguo 29-10-2012
Comandant Comandant is offline
Miembro
NULL
 
Registrado: ago 2012
Ubicación: Salta
Posts: 34
Reputación: 0
Comandant Va por buen camino
Alguien sabe utilizar las nuevas librerias de cifrado del Ing. Seaone?

Hola como dice el titulo alguien a utilizado las nuevas librerías de cifrado AES de el Ing Seaone en delphi XE porque no he podido cifrar un texto de mas de 16 caracteres porque el State es de 16 bits? alguien sabe como aumentar su capacidad o que se dinámico o no se puede? despues quize usar los stream pero me quede en el Create y no entendí bien como leer y escribir. Disculpen mi ignorancia pero quisiera entender como se usan ya que se que son muy conocidas por aquí.

http://code.google.com/p/secrypt/
Código Delphi [-]
uses SeAES256, SeBase64, SeSHA256, SeStreams;
procedure TForm1.Button1Click(Sender: TObject)
var
   Key: AnsiString;
   PlainText: AnsiString;
   AESKey: TAESKey;
   ExpandedKey: TAESExpandedKey;
   State: TAESState;
 begin
   // Clave de 32 bytes de longitud
   Key:= '12345678901234567890123456789012';
   {  #$60#$3d#$eb#$10#$15#$ca#$71#$be#$2b#$73#$ae#$f0#$85#$7d#$77#$81 +
     #$1f#$35#$2c#$07#$3b#$61#$08#$d7#$2d#$98#$10#$a3#$09#$14#$df#$f4;}
   // Texto plano de 16 bytes de longitud
   PlainText:=
     'No puedo meter mas de 16 caracteres';
   AESCopyKey(AESKey,PAnsiChar(Key));
   AESExpandKey(ExpandedKey,AESKey);
   move(PAnsiChar(PlainText)^,State,Sizeof(State));
   AESEncrypt(State,ExpandedKey);
   memo1.Lines.Add(Copy(PAnsiChar(@State),1,Sizeof(State)));
   AESDecrypt(State,ExpandedKey);
   memo2.Lines.Add( 'Bloque = ' + Copy(PAnsiChar(@State),1,Sizeof(State)));
end;

Código Delphi [-]
// Prepara la clave
function CalcularClave(Clave: AnsiString): TAESExpandedKey;
var
  Key: TAESKey;
begin
  // Usamos como Key el hash SHA256 de la Clave
  TSHA256HASH(Key):= CalcSHA256(Clave);
  AEsExpandKey(Result,Key);
end;
 
function Cifrar(Str: AnsiString; Clave: TAESExpandedKey): String;
var
  Dst: TStringStream;
  AStream: TAESEnc;
  BStream: TBase64Enc;
begin
  Dst:= TStringStream.Create(EmptyStr);
  try
    BStream:= TBase64Enc.Create(Dst);
    AStream:= TAESEnc.Create(BStream,Clave);
    try
     AStream.Write(PAnsiChar(Str)^,Length(Str));
    finally
      AStream.Free;
      BStream.Free;
    end;
    Result:= Dst.DataString;
  finally
    Dst.Free;
  end;
end;
 
function Descifrar(Str: AnsiString; Clave: TAESExpandedKey): String;
var
  Dst: TStringStream;
  AStream: TAESDec;
  BStream: TBase64Dec;
begin
  Dst:= TStringStream.Create(EmptyStr);
  try
    AStream:= TAESDec.Create(Dst,Clave);
    BStream:= TBase64Dec.Create(AStream);
    try
     BStream.Write(PAnsiChar(Str)^,Length(Str));
    finally
      BStream.Free;
      AStream.Free;
    end;
    Result:= Dst.DataString;
  finally
    Dst.Free;
  end;
end;

ahi estan los ejemplos pero que no he podido resolverlos, se que la mejor persona es Seaone para que me responda pero es mejor por foro para que quede archivado que no?. Gracias manes
Responder Con Cita