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
(Perl) Generating Repeatable Random Data for Testing/DebuggingDemonstrates how to use the Fortuna PRNG to generate random-looking but repeatable non-random data for the purpose of testing and debugging.
use chilkat(); # All Chilkat classes can be unlocked at once at the beginning of a program # by calling UnlockBundle. It requires a Bundle unlock code. $chilkatGlob = chilkat::CkGlobal->new(); $success = $chilkatGlob->UnlockBundle("Anything for 30-day trial."); if ($success != 1) { print $chilkatGlob->lastErrorText() . "\r\n"; exit; } $fortuna = chilkat::CkPrng->new(); # Normally an application would seed the PRNG with entropy from # some real random source. However, sometimes we want the same # random sequence of bytes for testing and debugging purposes. # This a reason why GetEntropy and AddEntropy are two different methods. # An application could omit the call to GetEntropy, and instead pass # non-random data to AddEntropy. For example: # Seed the PRNG with non-entropy, so we get a repeatable sequence. # Note: AddEntropy can be called any number of times. $success = $fortuna->AddEntropy("01020304","hex"); $success = $fortuna->AddEntropy("hello world","ascii"); # Generate some random data: $strRandHex = $fortuna->genRandom(16,"hex"); $strRandBase64 = $fortuna->genRandom(22,"base64"); $strRandBase58 = $fortuna->genRandom(32,"base58"); print "hex random bytes: " . $strRandHex . "\r\n"; print "base64 random bytes: " . $strRandBase64 . "\r\n"; print "base58 random bytes: " . $strRandBase58 . "\r\n"; # Try it again with a different object to verify that the same results are obtained: $fortuna2 = chilkat::CkPrng->new(); $success = $fortuna2->AddEntropy("01020304","hex"); $success = $fortuna2->AddEntropy("hello world","ascii"); $strRandHex = $fortuna2->genRandom(16,"hex"); $strRandBase64 = $fortuna2->genRandom(22,"base64"); $strRandBase58 = $fortuna2->genRandom(32,"base58"); print "hex random bytes: " . $strRandHex . "\r\n"; print "base64 random bytes: " . $strRandBase64 . "\r\n"; print "base58 random bytes: " . $strRandBase58 . "\r\n"; |
© 2000-2025 Chilkat Software, Inc. All Rights Reserved.