在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 = https://www.yisu.com/ask/cipher.update(data) + cipher.final'AES-256-CBC') cipher.decrypt cipher.key = key cipher.iv = iv decrypted_data = https://www.yisu.com/ask/cipher.update(encrypted_data) + cipher.final'your-secret-key' # 请使用一个安全的密钥,长度为32个字符(256位) data = 'https://www.yisu.com/ask/Hello, World!' encrypted_data, iv = encrypt(data, key) puts "Encrypted data: #{encrypted_data}" puts "Initialization vector: #{iv}" decrypted_data = https://www.yisu.com/ask/decrypt(encrypted_data, key, iv)"Decrypted data: #{decrypted_data}"
在这个示例中,我们定义了两个方法:encrypt
和decrypt
。encrypt
方法接受一个字符串(数据)和一个密钥,然后使用AES-256-CBC加密算法对其进行加密。decrypt
方法接受加密数据、密钥和初始化向量(IV),然后使用相同的算法对其进行解密。
请注意,您需要使用一个安全的密钥,长度为32个字符(256位)。在实际应用中,请确保妥善保管密钥。
要运行此示例,请在命令行中输入以下命令:
ruby encrypt_decrypt.rb
这将显示加密后的数据和初始化向量。然后,您可以使用相同的密钥和IV对加密数据进行解密,以恢复原始数据。