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
(Classic ASP) RSA Encrypt and Decrypt StringsClassic ASP sample code to RSA public-key encrypt and decrypt strings using public and private keys.
<html> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8"> </head> <body> <% ' This example assumes the Chilkat API to have been previously unlocked. ' See Global Unlock Sample for sample code. ' For versions of Chilkat < 10.0.0, use CreateObject("Chilkat_9_5_0.Rsa") set rsa = Server.CreateObject("Chilkat.Rsa") ' This example also generates the public and private ' keys to be used in the RSA encryption. ' Normally, you would generate a key pair once, ' and distribute the public key to your partner. ' Anything encrypted with the public key can be ' decrypted with the private key. The reverse is ' also true: anything encrypted using the private ' key can be decrypted using the public key. ' Generate a 1024-bit key. Chilkat RSA supports ' key sizes ranging from 512 bits to 4096 bits. success = rsa.GenerateKey(1024) If (success <> 1) Then Response.Write "<pre>" & Server.HTMLEncode( rsa.LastErrorText) & "</pre>" Response.End End If ' Keys are exported in XML format: publicKey = rsa.ExportPublicKey() privateKey = rsa.ExportPrivateKey() plainText = "Encrypting and decrypting should be easy!" ' Start with a new RSA object to demonstrate that all we ' need are the keys previously exported: ' For versions of Chilkat < 10.0.0, use CreateObject("Chilkat_9_5_0.Rsa") set rsaEncryptor = Server.CreateObject("Chilkat.Rsa") ' Encrypted output is always binary. In this case, we want ' to encode the encrypted bytes in a printable string. ' Our choices are "hex", "base64", "url", "quoted-printable". rsaEncryptor.EncodingMode = "hex" ' We'll encrypt with the public key and decrypt with the private ' key. It's also possible to do the reverse. success = rsaEncryptor.ImportPublicKey(publicKey) usePrivateKey = 0 encryptedStr = rsaEncryptor.EncryptStringENC(plainText,usePrivateKey) Response.Write "<pre>" & Server.HTMLEncode( encryptedStr) & "</pre>" ' Now decrypt: ' For versions of Chilkat < 10.0.0, use CreateObject("Chilkat_9_5_0.Rsa") set rsaDecryptor = Server.CreateObject("Chilkat.Rsa") rsaDecryptor.EncodingMode = "hex" success = rsaDecryptor.ImportPrivateKey(privateKey) usePrivateKey = 1 decryptedStr = rsaDecryptor.DecryptStringENC(encryptedStr,usePrivateKey) Response.Write "<pre>" & Server.HTMLEncode( decryptedStr) & "</pre>" %> </body> </html> |
© 2000-2025 Chilkat Software, Inc. All Rights Reserved.