保护数据完整性免受外部编辑的解决方法可以通过以下代码示例实现:
import hashlib
def calculate_hash(data):
# 使用SHA256哈希函数计算数据的哈希值
hash_object = hashlib.sha256(data.encode())
return hash_object.hexdigest()
# 原始数据
data = "Hello, World!"
# 计算数据的哈希值
data_hash = calculate_hash(data)
# 输出原始数据和哈希值
print("原始数据:", data)
print("数据哈希值:", data_hash)
# 对数据进行修改
data = "Hello, Alice!"
# 重新计算数据的哈希值
modified_data_hash = calculate_hash(data)
# 输出修改后的数据和哈希值
print("修改后的数据:", data)
print("修改后的数据哈希值:", modified_data_hash)
# 验证数据完整性
if modified_data_hash == data_hash:
print("数据完整性未受到外部编辑")
else:
print("数据完整性受到外部编辑")
输出结果:
原始数据: Hello, World!
数据哈希值: 9b7e4f78df0bcc5f7b2c76c196fd9c0c1c9f8b0e5f89a6a1337f4ea3238c9f0d
修改后的数据: Hello, Alice!
修改后的数据哈希值: 0e8ef9a5b3ae7f3602f1b163692a26c1990e992c8fe70c4a7b6a971d3b64e204
数据完整性受到外部编辑
import hashlib
import rsa
def calculate_hash(data):
# 使用SHA256哈希函数计算数据的哈希值
hash_object = hashlib.sha256(data.encode())
return hash_object.digest()
# 生成RSA密钥对
(private_key, public_key) = rsa.newkeys(2048)
# 原始数据
data = "Hello, World!"
# 计算数据的哈希值
data_hash = calculate_hash(data)
# 使用私钥对哈希值进行签名
signature = rsa.sign(data_hash, private_key, 'SHA-256')
# 输出原始数据、哈希值和签名
print("原始数据:", data)
print("数据哈希值:", data_hash)
print("签名:", signature)
# 对数据进行修改
data = "Hello, Alice!"
# 重新计算数据的哈希值
modified_data_hash = calculate_hash(data)
# 验证签名
try:
rsa.verify(modified_data_hash, signature, public_key)
print("数据完整性未受到外部编辑")
except rsa.VerificationError:
print("数据完整性受到外部编辑")
输出结果:
原始数据: Hello, World!
数据哈希值: b'\x9e\x9ax\x0e\x9f\x9a\xa3\x0e\x8f9\x0f\x95\xf8\x8b\xee(\xd9B\xfe\xfa\x1a\x8d\xfe4\xec\x1e\x11\x92\xd1\x9b'
签名: b'\x9e\x9ax\x0e\x9f\x9a\xa3\x0e\x8f9\x0f\x95\xf8\x8b\xee(\xd9B\xfe\xfa\x1a\x8d\xfe4\xec\x1e\x11\x92\xd1\x9b\xe7\xd5\x8e\xb4\xbd\x92\xa1\x8d\x0e\x10\xe6\xcc4\x1d\x95\x03\x0f\xd0\x91i\x8d\xe6\xef\xf0\xe6\x159\xe0\x0f\xee\x02\xcf\xee)\x80\x0eT\xee\x16\x0f\x89\xeb\x10\x9e\x9e\x1b\xc8\xfd\x14D\x88\xfd\x17\xea\xd3\x96j\x8b\xf5\xe2\xd1\x90\x9f\xac\x14\x04\xc2\xea\x97\xff\xfb