Chilkat HOME .NET Core C# Android™ AutoIt C C# C++ Chilkat2-Python CkPython Classic ASP DataFlex Delphi ActiveX Delphi DLL Go Java Lianja Mono C# Node.js Objective-C PHP ActiveX PHP Extension Perl PowerBuilder PowerShell PureBasic Ruby SQL Server Swift 2 Swift 3,4,5... 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 <C_CkGlobalW.h> #include <C_CkPrngW.h> void ChilkatSample(void) { HCkGlobalW chilkatGlob; BOOL success; HCkPrngW fortuna; const wchar_t *strEntropy; const wchar_t *strRandHex; const wchar_t *strRandBase64; const wchar_t *strRandBase58; // All Chilkat classes can be unlocked at once at the beginning of a program // by calling UnlockBundle. It requires a Bundle unlock code. chilkatGlob = CkGlobalW_Create(); success = CkGlobalW_UnlockBundle(chilkatGlob,L"Anything for 30-day trial."); if (success != TRUE) { wprintf(L"%s\n",CkGlobalW_lastErrorText(chilkatGlob)); CkGlobalW_Dispose(chilkatGlob); return; } fortuna = CkPrngW_Create(); // 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. strEntropy = CkPrngW_getEntropy(fortuna,32,L"hex"); if (CkPrngW_getLastMethodSuccess(fortuna) != TRUE) { wprintf(L"%s\n",CkPrngW_lastErrorText(fortuna)); CkGlobalW_Dispose(chilkatGlob); CkPrngW_Dispose(fortuna); return; } // Seed the PRNG with this entropy: success = CkPrngW_AddEntropy(fortuna,strEntropy,L"hex"); if (success != TRUE) { wprintf(L"%s\n",CkPrngW_lastErrorText(fortuna)); CkGlobalW_Dispose(chilkatGlob); CkPrngW_Dispose(fortuna); return; } // Generate some random data: strRandHex = CkPrngW_genRandom(fortuna,16,L"hex"); strRandBase64 = CkPrngW_genRandom(fortuna,22,L"base64"); strRandBase58 = CkPrngW_genRandom(fortuna,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); CkGlobalW_Dispose(chilkatGlob); CkPrngW_Dispose(fortuna); } |
© 2000-2024 Chilkat Software, Inc. All Rights Reserved.