在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字节。你可以根据需要选择其他加密算法和密钥长度。在实际应用中,请确保密钥的安全存储和管理。