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
(PHP Extension) 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.)
<?php // The version number (9_5_0) should match version of the Chilkat extension used, omitting the micro-version number. // For example, if using Chilkat v9.5.0.48, then include as shown here: include("chilkat_9_5_0.php"); // All Chilkat classes can be unlocked at once at the beginning of a program // by calling UnlockBundle. It requires a Bundle unlock code. $chilkatGlob = new CkGlobal(); $success = $chilkatGlob->UnlockBundle('Anything for 30-day trial.'); if ($success != true) { print $chilkatGlob->lastErrorText() . "\n"; exit; } $fortuna = new CkPrng(); // 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 = $fortuna->getEntropy(32,'hex'); if ($fortuna->get_LastMethodSuccess() != true) { print $fortuna->lastErrorText() . "\n"; exit; } // Seed the PRNG with this entropy: $success = $fortuna->AddEntropy($strEntropy,'hex'); if ($success != true) { print $fortuna->lastErrorText() . "\n"; exit; } // Generate some random data: $strRandHex = $fortuna->genRandom(16,'hex'); $strRandBase64 = $fortuna->genRandom(22,'base64'); $strRandBase58 = $fortuna->genRandom(32,'base58'); print 'hex random bytes: ' . $strRandHex . "\n"; print 'base64 random bytes: ' . $strRandBase64 . "\n"; print 'base58 random bytes: ' . $strRandBase58 . "\n"; ?> |
© 2000-2024 Chilkat Software, Inc. All Rights Reserved.