Chilkat HOME ASP Visual Basic VB.NET C# Visual C++ C MFC Delphi FoxPro Java Perl PHP Python Ruby SQL Server VBScript
|
ASCII / ANSI Secret Key in Symmetric EncryptionUsing an ASCII (or ANSI) secret key w/ symmetric encryption: AES, Blowfish, Twofish, RC2, 3DES, etc.
Dim fso, outFile Set fso = CreateObject("Scripting.FileSystemObject") Set outFile = fso.CreateTextFile("output.txt", True) set crypt = CreateObject("Chilkat.Crypt2") success = crypt.UnlockComponent("Anything for 30-day trial") If (success <> 1) Then MsgBox "Crypt component unlock failed" WScript.Quit End If ' A frequent support question goes something like this: ' ------------------ ' I am not able to decrypt strings encrypted using ' cryptix.jce.provider.key.RawSecretKey (Java) like I would normally do. ' The key generation is being done with the Rijndael algorithm (256-bit) ' The AES encryption algorithm is "Rijndael/ECB/PKCS#5" ' The 32 character source key I'm using is this: ' 1234567890123456789012345678912 ' ' ------------------ ' The customer tries to call GenerateSecretKey to ' convert the 32-character source key to a binary secret key, ' but this is incorrect (in this case). GenerateSecretKey ' hashes a string of any length and produces binary hash output ' that is of the appropriate size to be used as a secret key. ' The telltale sign is that in this case, the string is the exact ' length of the secret key. 32 ANSI characters = 256 bits. ' Therefore, it is obvious that the bytes of the binary ' secret key should be the exact ascii character values ' of the string. encKey = "1234567890123456789012345678912" crypt.CryptAlgorithm = "aes" ' Mode is "ecb" or "cbc" crypt.CipherMode = "ecb" crypt.KeyLength = 256 ' Call SetEncodedKey with "ascii" to tell the component ' to use the ascii-bytes as the binary secret key. ' Make sure you call this after setting the KeyLength. crypt.SetEncodedKey encKey,"ascii" crypt.EncodingMode = "base64" text = "The quick brown fox jumped over the lazy dog." ' Encrypt a string and return the binary encrypted data ' in a base-64 encoded string. encText = crypt.EncryptStringENC(text) outFile.WriteLine(encText) ' Decrypt and show the original string: decryptedText = crypt.DecryptStringENC(encText) outFile.WriteLine(decryptedText) outFile.Close |
Need a specific example? Send a request to support@chilkatsoft.com
© 2003-2007 Chilkat Software, Inc. All Rights Reserved.