在Ruby中,可以使用多種庫來實現加密和解密。這里,我將向您展示如何使用OpenSSL庫進行加密和解密操作。OpenSSL是一個強大且廣泛使用的加密庫,支持多種加密算法。
首先,確保已經安裝了OpenSSL庫。在大多數Linux發行版中,可以使用以下命令安裝:
sudo apt-get install openssl
接下來,我們將使用Ruby的OpenSSL
庫進行加密和解密操作。以下是一個簡單的示例:
require 'openssl'
require 'base64'
# 生成密鑰對
def generate_key_pair
key = OpenSSL::PKey::RSA.new(2048)
puts "Private Key:"
puts key.to_pem
puts "Public Key:"
puts key.public_key.to_pem
[key, key.public_key]
end
# 加密函數
def encrypt(data, public_key)
cipher = OpenSSL::Cipher.new('RSA-OAEP')
cipher.encrypt
cipher.key = public_key
encrypted_data = cipher.update(data) + cipher.final
Base64.encode64(encrypted_data)
end
# 解密函數
def decrypt(encrypted_data, private_key)
cipher = OpenSSL::Cipher.new('RSA-OAEP')
cipher.decrypt
cipher.key = private_key
decrypted_data = cipher.update(Base64.decode64(encrypted_data)) + cipher.final
decrypted_data
end
# 示例
key_pair = generate_key_pair
public_key, private_key = key_pair
data = "Hello, World!"
encrypted_data = encrypt(data, public_key)
puts "Encrypted Data:"
puts encrypted_data
decrypted_data = decrypt(encrypted_data, private_key)
puts "Decrypted Data:"
puts decrypted_data
在這個示例中,我們首先生成了一個RSA密鑰對,然后使用公鑰進行加密,私鑰進行解密。注意,這里使用了RSA-OAEP
加密算法,它是一種安全的加密算法。
您可以根據需要修改這個示例,以適應不同的加密算法和密鑰長度。在實際應用中,您可能需要處理更復雜的數據和密鑰管理任務。在這種情況下,可以考慮使用更高級的加密庫,如RbNaCl
。