在Ruby中,可以使用多种方法进行数据加密和解密。这里,我将向您展示如何使用Ruby内置的OpenSSL
库进行数据加密和解密操作。
首先,确保已经安装了Ruby,然后创建一个新的Ruby文件(例如:encrypt_decrypt.rb),并在其中编写以下代码:
require 'openssl'
def encrypt(data, key)
cipher = OpenSSL::Cipher.new('AES-256-CBC')
cipher.encrypt
cipher.key = key
cipher.iv = cipher.random_iv
encrypted_data = cipher.update(data) + cipher.final
[encrypted_data, cipher.iv]
end
def decrypt(encrypted_data, key, iv)
cipher = OpenSSL::Cipher.new('AES-256-CBC')
cipher.decrypt
cipher.key = key
cipher.iv = iv
decrypted_data = cipher.update(encrypted_data) + cipher.final
decrypted_data
end
# 示例用法
key = 'your-secret-key' # 请使用一个安全的密钥,长度为32个字符(256位)
data = 'Hello, World!'
encrypted_data, iv = encrypt(data, key)
puts "Encrypted data: #{encrypted_data}"
puts "Initialization vector: #{iv}"
decrypted_data = decrypt(encrypted_data, key, iv)
puts "Decrypted data: #{decrypted_data}"
在这个示例中,我们定义了两个方法:encrypt
和decrypt
。encrypt
方法接受一个字符串(数据)和一个密钥,然后使用AES-256-CBC加密算法对其进行加密。decrypt
方法接受加密数据、密钥和初始化向量(IV),然后使用相同的算法对其进行解密。
请注意,您需要使用一个安全的密钥,长度为32个字符(256位)。在实际应用中,请确保妥善保管密钥。
要运行此示例,请在命令行中输入以下命令:
ruby encrypt_decrypt.rb
这将显示加密后的数据和初始化向量。然后,您可以使用相同的密钥和IV对加密数据进行解密,以恢复原始数据。