Ruby Examples

ChilkatHOMEASPVisual BasicVB.NETC#Visual C++CMFCDelphiFoxProJavaPerlPHPPythonRubySQL ServerVBScript

Ruby
Examples

Quick Start
Unicode
Byte Array
Bz2
Certificates
CSV
Email
Encryption
FTP
HTML-to-XML
HTTP
IMAP
MHT
MIME
POP3
RSA
S/MIME
Signatures
SFTP
SMTP
Socket / SSL
Spider
SSH
SSH Key
SSH Tunnel
Tar
HTTP Upload
XML
XMP
Zip

More Examples...
String
Email Object
DKIM / DomainKey
NTLM
FileAccess
RSS
Atom
Self-Extractor
Service
PPMD
Deflate
Bzip2
DH Key Exchange
DSA
LZW

 

 

 

 

 

 

 

RSA Encrypt and Decrypt Credit Card Numbers

Ruby sample code to RSA public-key encrypt and decrypt credit card numbers. The RSA key is loaded from an unencrypted PKCS8 file. Chilkat provides many ways of setting the key -- loading from both encrypted and unencrypted PEM, PKCS8, DER, PVK, etc. Keys may be loaded from files or in-memory representations. (The RSA component also provides the ability to generate RSA keys.)

Download Chilkat Ruby Library

require 'chilkat'

rsa = Chilkat::CkRsa.new()

success = rsa.UnlockComponent("Anything for 30-day trial")
if (success != true)
    print rsa.lastErrorText() + "\n"
    exit
end

key = Chilkat::CkPrivateKey.new()

#  Load an RSA private key from a PKCS8 file:
success = key.LoadPkcs8File("rsaPrivateKey.p8")
if (success != true)
    print key.lastErrorText() + "\n"
    exit
end

#  Get the key as XML:

keyXml = key.getXml()

#  We'll encrypt with the public key and decrypt with the private
#  key.  (It's also possible to do the reverse.)
#  Note: An RSA private key is composed of different parts internally: modulus, exponent, P, Q, etc.
#  An RSA public-key is a sub-set of the private key.
#  Therefore, when you have a private key, you really have
#  both public and private keys.
success = rsa.ImportPublicKey(keyXml)
if (success != true)
    print rsa.lastErrorText() + "\n"
    exit
end

#  Encrypt a VISA credit card number:
#  1234-5678-0000-9999
ccNumber = "1234567800009999"

usePrivateKey = false
rsa.put_EncodingMode("base64")
encryptedStr = rsa.encryptStringENC(ccNumber,usePrivateKey)
print "Encrypted:" + "\n";
print encryptedStr + "\n";

#  Now decrypt:
rsaDecryptor = Chilkat::CkRsa.new()

rsaDecryptor.put_EncodingMode("base64")
rsaDecryptor.ImportPrivateKey(keyXml)

usePrivateKey = true
decryptedStr = rsaDecryptor.decryptStringENC(encryptedStr,usePrivateKey)

print "Decrypted:" + "\n";
print decryptedStr + "\n";

#  Important: RSA encryption should only be used to encrypt small amounts of data.
#  It is typically used for encrypting symmetric encryption
#  keys such that a symmetric encryption algorithm, such as
#  AES is then used to encrypt/decrypt bulk data.

 

Need a specific example? Send a request to support@chilkatsoft.com

© 2000-2010 Chilkat Software, Inc. All Rights Reserved.