日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 编程语言 > python >内容正文

python

python导出excel文件数字签名_Python使用RSA+MD5实现数字签名

發(fā)布時(shí)間:2024/7/23 python 46 豆豆
生活随笔 收集整理的這篇文章主要介紹了 python导出excel文件数字签名_Python使用RSA+MD5实现数字签名 小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

數(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)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。