在Ruby中,你可以使用内置的OpenSSL
库来进行加密和解密操作。以下是一个简单的示例,展示了如何使用AES加密和解密字符串:
require 'openssl'
require 'base64'
def encrypt(str, key)
cipher = OpenSSL::Cipher.new('AES-256-CBC')
cipher.encrypt
cipher.key = key
cipher.iv = cipher.random_iv
encrypted_str = cipher.update(str) + cipher.final
Base64.encode64(encrypted_str)
end
def decrypt(encrypted_str, key)
cipher = OpenSSL::Cipher.new('AES-256-CBC')
cipher.decrypt
cipher.key = key
cipher.iv = Base64.decode64(encrypted_str)[0..15] # 使用Base64解码后的IV
decrypted_str = cipher.update(Base64.decode64(encrypted_str)[16..-1]) + cipher.final
decrypted_str
end
# 示例
key = 'your-secret-key-here-16bytes' # 确保密钥长度为16、24或32字节
str = 'Hello, World!'
encrypted_str = encrypt(str, key)
puts "Encrypted: #{encrypted_str}"
decrypted_str = decrypt(encrypted_str, key)
puts "Decrypted: #{decrypted_str}"
请注意,这个示例使用了AES-256-CBC加密算法,密钥长度为16字节。你可以根据需要选择其他加密算法和密钥长度。在实际应用中,请确保密钥的安全存储和管理。