python导出excel文件数字签名_Python使用RSA+MD5实现数字签名
數字簽名主要有防抵賴和防篡改兩種功能:一是能確定消息確實是由發送方簽名并發出來的,因為別人假冒不了發送方的簽名,二是能確定消息的完整性。
作為具體實現,發送報文時,發送方用一個哈希函數(例如MD5、SHA-1、SHA-256、SHA-384或SHA-512)從報文文本中生成報文摘要,然后用自己的私鑰(由RSA或其他公鑰密碼體制算法生成,只有發送方本人知道,需保密)對這個摘要進行加密,這個加密后的摘要將作為報文的數字簽名和報文一起發送給接收方,接收方首先用與發送方一樣的哈希函數從接收到的原始報文中計算出報文摘要,接著再用發送方的公鑰(必須與發送方的私鑰配對使用,無法對其他人私鑰加密的信息進行正確解密)來對報文附加的數字簽名進行解密,如果能夠正確解密并且這兩個摘要相同、那么接收方就能確認該數字簽名是發送方的。
下面的代碼演示了Python擴展庫rsa中數字簽名的用法。
>>> import rsa
#生成配對的公鑰和私鑰
>>> publicKey, privateKey = rsa.newkeys(3000)
>>> message = 'Hello world.'
#簽名,也可以指定其他哈希算法
>>> signature = rsa.sign(message.encode(), privateKey, 'MD5')
#驗證簽名
>>> print(rsa.verify(message.encode(), signature, publicKey))
True
#消息錯誤
>>> print(rsa.verify('message'.encode(), signature, publicKey))
Traceback (most recent call last):
File "", line 1, in
print(rsa.verify('message'.encode(), signature, publicKey))
File "C:\Python 3.5\lib\site-packages\rsa\pkcs1.py", line 322, in verify
raise VerificationError('Verification failed')
rsa.pkcs1.VerificationError: Verification failed
#簽名錯誤
>>> print(rsa.verify(message.encode(), signature+b'0', publicKey))
Traceback (most recent call last):
File "", line 1, in
print(rsa.verify(message.encode(), signature+b'0', publicKey))
File "C:\Python 3.5\lib\site-packages\rsa\pkcs1.py", line 308, in verify
raise VerificationError('Verification failed')
rsa.pkcs1.VerificationError: Verification failed
總結
以上是生活随笔為你收集整理的python导出excel文件数字签名_Python使用RSA+MD5实现数字签名的全部內容,希望文章能夠幫你解決所遇到的問題。
 
                            
                        - 上一篇: 【LeetCode笔记】46. 全排列(
- 下一篇: 【学习笔记】路由算法与路由协议:RIP协
