python导出excel文件数字签名_Python使用RSA+MD5实现数字签名
數(shù)字簽名主要有防抵賴和防篡改兩種功能:一是能確定消息確實(shí)是由發(fā)送方簽名并發(fā)出來的,因?yàn)閯e人假冒不了發(fā)送方的簽名,二是能確定消息的完整性。
作為具體實(shí)現(xiàn),發(fā)送報(bào)文時(shí),發(fā)送方用一個(gè)哈希函數(shù)(例如MD5、SHA-1、SHA-256、SHA-384或SHA-512)從報(bào)文文本中生成報(bào)文摘要,然后用自己的私鑰(由RSA或其他公鑰密碼體制算法生成,只有發(fā)送方本人知道,需保密)對這個(gè)摘要進(jìn)行加密,這個(gè)加密后的摘要將作為報(bào)文的數(shù)字簽名和報(bào)文一起發(fā)送給接收方,接收方首先用與發(fā)送方一樣的哈希函數(shù)從接收到的原始報(bào)文中計(jì)算出報(bào)文摘要,接著再用發(fā)送方的公鑰(必須與發(fā)送方的私鑰配對使用,無法對其他人私鑰加密的信息進(jìn)行正確解密)來對報(bào)文附加的數(shù)字簽名進(jìn)行解密,如果能夠正確解密并且這兩個(gè)摘要相同、那么接收方就能確認(rèn)該數(shù)字簽名是發(fā)送方的。
下面的代碼演示了Python擴(kuò)展庫rsa中數(shù)字簽名的用法。
>>> import rsa
#生成配對的公鑰和私鑰
>>> publicKey, privateKey = rsa.newkeys(3000)
>>> message = 'Hello world.'
#簽名,也可以指定其他哈希算法
>>> signature = rsa.sign(message.encode(), privateKey, 'MD5')
#驗(yàn)證簽名
>>> print(rsa.verify(message.encode(), signature, publicKey))
True
#消息錯(cuò)誤
>>> 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
#簽名錯(cuò)誤
>>> 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
總結(jié)
以上是生活随笔為你收集整理的python导出excel文件数字签名_Python使用RSA+MD5实现数字签名的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 【LeetCode笔记】46. 全排列(
- 下一篇: python读json文件中不同的数据类