Delphi有加密安全的PRNG库吗?

dom*_*mer 9 delphi random

任何人都可以为Delphi(Win32)推荐一个加密安全的伪随机数生成器库吗?

可以是免费的或商业的,但理想情况下是一个活跃的项目.我希望它包含源代码.

vcl*_*per 8

您可以使用Windows CryptoAPI:

uses Wcrypt2;

function GenerateRandom(Len: Cardinal): TBytes;
var
  hProv : HCRYPTPROV;
begin
  if not CryptAcquireContext(@hProv,
                             nil,
                             MS_ENHANCED_PROV,
                             PROV_RSA_FULL,
                             CRYPT_VERIFYCONTEXT) then
    CryptAcquireContext(@hProv,
                        nil,
                        MS_ENHANCED_PROV,
                        PROV_RSA_FULL,
                        CRYPT_NEWKEYSET + CRYPT_VERIFYCONTEXT);

  if hProv > 0 then
  try
    SetLength(Result,Len);
    CryptGenRandom(hProv,Len,@Result[0]);
  finally
    CryptReleaseContext(hProv,0);
  end;
end;
Run Code Online (Sandbox Code Playgroud)

使用上面代码的示例:

function BytesToHex(const Bytes: TBytes): string;
var
  i : integer;
begin
  for i := 0 to Length(Bytes)-1 do
    Result := Result + IntToHex(Bytes[i],2);
end;

procedure TForm1.Button1Click(Sender: TObject);
begin
  ShowMessage(BytesToHex(GenerateRandom(16)));
end;
Run Code Online (Sandbox Code Playgroud)

  • 只有在GetLastError = NTE_BAD_KEYSET时才应执行第二个CryptAcquireContext.否则代码应引发异常(RaiseLastOSError)或返回空数组.MSDN来源:http://msdn.microsoft.com/en-us/library/windows/desktop/aa379886(v = vs.85).aspx (2认同)

Leo*_*Leo 5

德尔福加密纲要(这是著名十岁上下的德国来说德尔福社区,但在其他地方-大概是因为它不是正式荣升)包含了加密的安全亚罗RNG.

只需包含单位DECRandom(也许DECUtils)并像这样使用它(此示例使用IInteger但不是强制性的):

function generateRandomNumber: IInteger; 
var 
  A: IInteger;  
begin 
  NRnd(A, 512);  // generate 512 Bit random number, 2^512 <= A < 2^513 
  Result := A;
end; 

initialization 
  // Method 1: uses system timer to initialize the RNG (seed)
  RandomSeed;   
  // Method 2: use own seed
  randomSeed(Data, SizeOf(Data));
Run Code Online (Sandbox Code Playgroud)