在Ruby中进行加密和解密的测试,你可以使用内置的加密库,如OpenSSL
。以下是一个简单的示例,展示了如何使用Ruby的OpenSSL
库进行加密和解密操作,并进行测试。
首先,确保你已经安装了Ruby。接下来,创建一个新的Ruby文件,例如crypto_test.rb
,并在其中编写以下代码:
require 'openssl'
require 'base64'
# 生成一个密钥对
def generate_key_pair
key = OpenSSL::PKey::RSA.new(2048)
cipher = OpenSSL::Cipher.new('AES-256-CBC')
cipher.encrypt
encrypted_data = cipher.update("Hello, World!") + cipher.final
[Base64.encode64(encrypted_data), Base64.encode64(key.public_key.to_der)]
end
# 加密数据
def encrypt_data(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
Base64.encode64(encrypted_data)
end
# 解密数据
def decrypt_data(encrypted_data, key)
cipher = OpenSSL::Cipher.new('AES-256-CBC')
cipher.decrypt
cipher.key = key
cipher.iv = Base64.decode64(encrypted_data[0...32]) # IV长度为16字节
decrypted_data = cipher.update(Base64.decode64(encrypted_data[32..-1])) + cipher.final
decrypted_data
end
# 测试加密和解密
key_pair = generate_key_pair
data = "Hello, World!"
encrypted_data = encrypt_data(data, key_pair[0])
puts "Encrypted data: #{encrypted_data}"
decrypted_data = decrypt_data(encrypted_data, key_pair[1])
puts "Decrypted data: #{decrypted_data}"
在这个示例中,我们首先定义了一个生成密钥对的方法generate_key_pair
,然后定义了加密和解密数据的方法encrypt_data
和decrypt_data
。最后,我们测试了加密和解密功能,确保它们能够正确地工作。
要运行这个测试,只需在命令行中输入以下命令:
ruby crypto_test.rb
如果一切正常,你将看到加密后的数据和解密后的原始数据。请注意,这个示例使用了AES-256-CBC加密算法,你可以根据需要更改它。同时,确保在实际应用中使用安全的密钥管理和传输方法。