parent
2a5a8a7687
commit
b214bb9115
@ -0,0 +1,90 @@
|
|||||||
|
from cryptography.hazmat.primitives.asymmetric import rsa, padding
|
||||||
|
from cryptography.hazmat.primitives import serialization, hashes
|
||||||
|
from cryptography.hazmat.backends import default_backend
|
||||||
|
import os
|
||||||
|
|
||||||
|
def encrypt_key():
|
||||||
|
# 获取当前脚本所在目录
|
||||||
|
current_directory = os.path.dirname(__file__)
|
||||||
|
|
||||||
|
# 读取对称密钥
|
||||||
|
symmetric_key_path = os.path.join(current_directory, 'symmetric_key.key')
|
||||||
|
|
||||||
|
if os.path.exists(symmetric_key_path):
|
||||||
|
with open(symmetric_key_path, 'rb') as symmetric_key_file:
|
||||||
|
symmetric_key = symmetric_key_file.read()
|
||||||
|
|
||||||
|
# 读取B的公钥
|
||||||
|
public_key_path = os.path.join(current_directory, 'B_public.txt')
|
||||||
|
|
||||||
|
if os.path.exists(public_key_path):
|
||||||
|
with open(public_key_path, 'rb') as public_key_file:
|
||||||
|
public_key = serialization.load_pem_public_key(
|
||||||
|
public_key_file.read(),
|
||||||
|
backend=default_backend()
|
||||||
|
)
|
||||||
|
|
||||||
|
# 使用RSA公钥加密对称密钥
|
||||||
|
encrypted_symmetric_key = public_key.encrypt(
|
||||||
|
symmetric_key,
|
||||||
|
padding.OAEP(
|
||||||
|
mgf=padding.MGF1(algorithm=hashes.SHA256()),
|
||||||
|
algorithm=hashes.SHA256(),
|
||||||
|
label=None
|
||||||
|
)
|
||||||
|
)
|
||||||
|
|
||||||
|
# 保存加密后的密文
|
||||||
|
encrypted_symmetric_key_path = os.path.join(current_directory, 'encrypted_symmetric_key.bin')
|
||||||
|
|
||||||
|
with open(encrypted_symmetric_key_path, 'wb') as encrypted_symmetric_key_file:
|
||||||
|
encrypted_symmetric_key_file.write(encrypted_symmetric_key)
|
||||||
|
|
||||||
|
print(f"对称密钥已读取并加密,加密后的对称密钥已保存到: {encrypted_symmetric_key_path}")
|
||||||
|
else:
|
||||||
|
print(f"B的公钥文件 {public_key_path} 不存在")
|
||||||
|
else:
|
||||||
|
print(f"对称密钥文件 {symmetric_key_path} 不存在")
|
||||||
|
|
||||||
|
def decrypt_key():
|
||||||
|
# 获取当前脚本所在目录
|
||||||
|
current_directory = os.path.dirname(__file__)
|
||||||
|
|
||||||
|
# 读取B的私钥
|
||||||
|
private_key_path = os.path.join(current_directory, 'B_private.txt')
|
||||||
|
|
||||||
|
if os.path.exists(private_key_path):
|
||||||
|
with open(private_key_path, 'rb') as private_key_file:
|
||||||
|
private_key = serialization.load_pem_private_key(
|
||||||
|
private_key_file.read(),
|
||||||
|
password=None,
|
||||||
|
backend=default_backend()
|
||||||
|
)
|
||||||
|
|
||||||
|
# 读取加密后的对称密钥
|
||||||
|
encrypted_symmetric_key_path = os.path.join(current_directory, 'encrypted_symmetric_key.bin')
|
||||||
|
|
||||||
|
if os.path.exists(encrypted_symmetric_key_path):
|
||||||
|
with open(encrypted_symmetric_key_path, 'rb') as encrypted_symmetric_key_file:
|
||||||
|
encrypted_symmetric_key = encrypted_symmetric_key_file.read()
|
||||||
|
|
||||||
|
# 使用B的私钥解密密文获得对称密钥
|
||||||
|
symmetric_key = private_key.decrypt(
|
||||||
|
encrypted_symmetric_key,
|
||||||
|
padding.OAEP(
|
||||||
|
mgf=padding.MGF1(algorithm=hashes.SHA256()),
|
||||||
|
algorithm=hashes.SHA256(),
|
||||||
|
label=None
|
||||||
|
)
|
||||||
|
)
|
||||||
|
|
||||||
|
# 保存解密后的对称密钥到文件
|
||||||
|
decrypt_symmetric_key_path = os.path.join(current_directory, 'decrypt_symmetric_key.key')
|
||||||
|
with open(decrypt_symmetric_key_path, 'wb') as decrypt_symmetric_key_file:
|
||||||
|
decrypt_symmetric_key_file.write(symmetric_key)
|
||||||
|
|
||||||
|
print(f"对称密钥已解密,得到的对称密钥已保存到: {decrypt_symmetric_key_path}")
|
||||||
|
else:
|
||||||
|
print(f"加密后的对称密钥文件 {encrypted_symmetric_key_path} 不存在")
|
||||||
|
else:
|
||||||
|
print(f"B的私钥文件 {private_key_path} 不存在")
|
Loading…
Reference in new issue