在Ruby中,可以使用多種方法進(jìn)行數(shù)據(jù)加密和解密。這里,我將向您展示如何使用Ruby內(nèi)置的OpenSSL
庫(kù)進(jìn)行數(shù)據(jù)加密和解密操作。
首先,確保已經(jīng)安裝了Ruby,然后創(chuàng)建一個(gè)新的Ruby文件(例如:encrypt_decrypt.rb),并在其中編寫(xiě)以下代碼:
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' # 請(qǐng)使用一個(gè)安全的密鑰,長(zhǎng)度為32個(gè)字符(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}"
在這個(gè)示例中,我們定義了兩個(gè)方法:encrypt
和decrypt
。encrypt
方法接受一個(gè)字符串(數(shù)據(jù))和一個(gè)密鑰,然后使用AES-256-CBC加密算法對(duì)其進(jìn)行加密。decrypt
方法接受加密數(shù)據(jù)、密鑰和初始化向量(IV),然后使用相同的算法對(duì)其進(jìn)行解密。
請(qǐng)注意,您需要使用一個(gè)安全的密鑰,長(zhǎng)度為32個(gè)字符(256位)。在實(shí)際應(yīng)用中,請(qǐng)確保妥善保管密鑰。
要運(yùn)行此示例,請(qǐng)?jiān)诿钚兄休斎胍韵旅睿?/p>
ruby encrypt_decrypt.rb
這將顯示加密后的數(shù)據(jù)和初始化向量。然后,您可以使用相同的密鑰和IV對(duì)加密數(shù)據(jù)進(jìn)行解密,以恢復(fù)原始數(shù)據(jù)。