|  | 
Chilkat  HOME  Android™  AutoIt  C  C#  C++  Chilkat2-Python  CkPython  Classic ASP  DataFlex  Delphi DLL  Go  Java  Node.js  Objective-C  PHP Extension  Perl  PowerBuilder  PowerShell  PureBasic  Ruby  SQL Server  Swift  Tcl  Unicode C  Unicode C++  VB.NET  VBScript  Visual Basic 6.0  Visual FoxPro  Xojo Plugin
| (Unicode C++) Fortuna PRNG Generate Random EncodedDemonstrates how to generate random bytes using the Fortuna PRNG. The random bytes are returned in an encoded string (using an encoding such as hex, base64, base58, etc.) 
 #include <CkGlobalW.h> #include <CkPrngW.h> void ChilkatSample(void) { // All Chilkat classes can be unlocked at once at the beginning of a program // by calling UnlockBundle. It requires a Bundle unlock code. CkGlobalW chilkatGlob; bool success = chilkatGlob.UnlockBundle(L"Anything for 30-day trial."); if (success != true) { wprintf(L"%s\n",chilkatGlob.lastErrorText()); return; } CkPrngW fortuna; // Before beginning to generate random data, // the PRNG (Pseudo Random Number Generator) should // be seeded with real random data (also known as "entropy"). // Note: Accumulating real random data can be difficult // and time-consuming to collect. It is for this reason // that pseudorandom data (i.e. a PRNG) is used. The pseudorandom data generator // is seeded with entropy. In addition, new entropy can (and should) // be periodically added as more pseudorandom data is generated. // Get 32 bytes of system entropy. On Linux/Unix systems, this reads // from /dev/random. On MS Windows systems, it uses the Crypto API's // CryptGenRandom function. const wchar_t *strEntropy = fortuna.getEntropy(32,L"hex"); if (fortuna.get_LastMethodSuccess() != true) { wprintf(L"%s\n",fortuna.lastErrorText()); return; } // Seed the PRNG with this entropy: success = fortuna.AddEntropy(strEntropy,L"hex"); if (success != true) { wprintf(L"%s\n",fortuna.lastErrorText()); return; } // Generate some random data: const wchar_t *strRandHex = fortuna.genRandom(16,L"hex"); const wchar_t *strRandBase64 = fortuna.genRandom(22,L"base64"); const wchar_t *strRandBase58 = fortuna.genRandom(32,L"base58"); wprintf(L"hex random bytes: %s\n",strRandHex); wprintf(L"base64 random bytes: %s\n",strRandBase64); wprintf(L"base58 random bytes: %s\n",strRandBase58); } | ||||||
© 2000-2025 Chilkat Software, Inc. All Rights Reserved.