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
(Objective-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.)
#import <CkoGlobal.h> #import <CkoPrng.h> #import <NSString.h> // All Chilkat classes can be unlocked at once at the beginning of a program // by calling UnlockBundle. It requires a Bundle unlock code. CkoGlobal *chilkatGlob = [[CkoGlobal alloc] init]; BOOL success = [chilkatGlob UnlockBundle: @"Anything for 30-day trial."]; if (success != YES) { NSLog(@"%@",chilkatGlob.LastErrorText); return; } CkoPrng *fortuna = [[CkoPrng alloc] init]; // 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. NSString *strEntropy = [fortuna GetEntropy: [NSNumber numberWithInt: 32] encoding: @"hex"]; if (fortuna.LastMethodSuccess != YES) { NSLog(@"%@",fortuna.LastErrorText); return; } // Seed the PRNG with this entropy: success = [fortuna AddEntropy: strEntropy encoding: @"hex"]; if (success != YES) { NSLog(@"%@",fortuna.LastErrorText); return; } // Generate some random data: NSString *strRandHex = [fortuna GenRandom: [NSNumber numberWithInt: 16] encoding: @"hex"]; NSString *strRandBase64 = [fortuna GenRandom: [NSNumber numberWithInt: 22] encoding: @"base64"]; NSString *strRandBase58 = [fortuna GenRandom: [NSNumber numberWithInt: 32] encoding: @"base58"]; NSLog(@"%@%@",@"hex random bytes: ",strRandHex); NSLog(@"%@%@",@"base64 random bytes: ",strRandBase64); NSLog(@"%@%@",@"base58 random bytes: ",strRandBase58); |
© 2000-2024 Chilkat Software, Inc. All Rights Reserved.