一次一密(One-time pad)是一种加密方法,其中使用一个随机的、只能使用一次的密钥与明文进行按位异或操作,以生成密文。这种加密方法是绝对安全的,前提是密钥必须具有真正的随机性且只能使用一次。
以下是使用Python实现一次一密加密和解密的代码:
import random
def one_time_pad_encrypt(plain_text):
key = ''.join([chr(random.randint(0, 255)) for _ in range(len(plain_text))])
encrypted_text = ''.join([chr(ord(plain_text[i]) ^ ord(key[i])) for i in range(len(plain_text)])
return encrypted_text, key
def one_time_pad_decrypt(encrypted_text, key):
decrypted_text = ''.join([chr(ord(encrypted_text[i]) ^ ord(key[i])) for i in range(len(encrypted_text)])
return decrypted_text
# 示例
plain_text = "Hello, World!"
encrypted_text, key = one_time_pad_encrypt(plain_text)
decrypted_text = one_time_pad_decrypt(encrypted_text, key)
print("Plain Text:", plain_text)
print("Encrypted Text:", encrypted_text)
print("Decrypted Text:", decrypted_text)
请注意,一次一密中密钥和明文的长度必须相同。在示例中,随机生成了一个密钥,它与明文进行异或操作生成密文,然后再使用密钥对密文进行解密操作。
请谨记,在实践中,一次一密加密方法很少使用,因为需要生成和保管相同长度的真正随机的密钥非常困难。