久久国产精品一区二区三区四区,久色婷婷小香蕉久久,国产日韩欧美在线播放不卡,另类av一区二区

20 行 Python 代碼實現加密通信
來源:Python中文社區    時間:2022-03-26 22:40:46
一、引言

網絡上充滿了竊聽,我們的信息很容易被不懷好意的人獲得,給我們造成不好的影響。如果你需要在網絡上傳輸機密或者敏感的隱私信息,為了防備別有用心的人竊聽,可能需要加密。而使用在線或者手機上的加密軟件,可能不良軟件更是泄露信息的溫床。所以作為程序員的我們,完全可以自己來實現一個加密系統。

本文用 20 行 Python 代碼來演示加密、解密、簽名、驗證的功能。大家依樣畫葫蘆,不僅能理解加密技術,更能自己實現一套加密通信機制。

加密、解密建立在較高深的數學理論之上,不建議大家自己實現加密算法,直接調用相應庫即可。

二、加密技術

加密技術我們這里演示兩種,分別是對稱加密和非對稱加密。

講解加密技術之前,我們需要假設下我們的使用場景,也是密碼學常見的設定。

Alice Bob是通信雙方Eve是一個竊聽者傳遞的消息是PlainText加密使用的秘鑰key加密后的密文是secret message三、普通鎖:簡單的對稱加密

對稱加密:加密和解密雙方使用同一個秘鑰。比如這里, key="1234567887654321".encode("utf-8"),這個 key 是 Alice 和 Bob 共同的密鑰。當 Alice 發消息時,他需要如下操作完成加密。

from Crypto.Cipher import AEScryptor = AES.new(key, AES.MODE_ECB)secret = cryptor.encrypt(plain.encode("utf-8"))secret = b64encode(secret)第一行 導入了AES算法。AES 是對稱加密的一種算法第二行 新建加密器,key 是秘鑰, AES.MODE_ECB 是信息填充模式第三行 完成 encrypt 加密第四行 加密后后的信息由 b64encode 編碼后,發送給 Bob。

HTTP 是文本協議,內容都是文本字符。想要對二進制文件進行傳輸,需要把它轉化為文本,Base64代碼就是用字符指代二進制的編碼形式。

Bob 收到信息之后,進行如下解碼、解密操作。

secret = b64decode(secret)plainText = cryptor.decrypt(secret).decode("utf-8")

得到的 plainText 是 Alice 發來的明文信息。

注意,兩個人用同一個秘鑰來加密、解密。

現在我們先來解決一個小問題:網絡經常丟包,導致 Alice 說話有時候缺頭少尾,這該怎么辦呢?

四、不可篡改的指紋:哈希函數

像人都有指紋一樣,傳遞的消息也有自己的指紋。哈希函數用來找到消息的指紋。哈希函數也稱為消息摘要函數,見名知意,是把一段內容提要出來,做成指紋。這個輸出(指紋)很有特點:

不論輸入多長,輸出長度固定,輸出看起來像亂碼。

輸入變一點,輸出有很大不同。

消息可推出指紋,指紋推不出消息。

靠著以上特性,Alice 可以把消息哈希一下,把哈希值和消息都給 Bob。Bob 也把消息哈希一下,如果兩個值一樣,表明這句話內容完整,沒有篡改和丟掉信息。

from hashlib import md5plainText = "I love you!"hash_ = md5(plainText.encode("utf-8")).hexdigest()

結果這樣:690a8cda8894e37a6fff4d1790d53b33。如果 Bob 也對這條消息哈希,結果相同的話,說明這條信息完整。

現在我們再來解決一個大問題:對稱加密如果秘鑰遺失了,被壞人 Eve 獲取之后,他完全可以竊聽 Alice 和 Bob 之間的通信,甚至可以偽裝成對方向另一方發送消息。

現在需要非對稱加密登場了。

五、矛與盾:非對稱加密

非對稱加密,就是加密和解密秘鑰不是一個,是一對。自己持有的稱為私鑰,交給對方的稱為公鑰。特點是:

公鑰加密,私鑰解密。私鑰加密,公鑰解密。私鑰可推導出公鑰,反之不行。

利用以上特點,我們可以實現安全的加密算法。首先 Bob 產生秘鑰,并保存為文件。

import rsaBob_pubkey, Bob_privkey = rsa.newkeys(512)with open("Bob-pri.pem", "wb")as prif, open("Bob-pub.pem", "wb")as pubf:prif.write(Bob_privkey.save_pkcs1())pubf.write(Bob_pubkey.save_pkcs1())

其中

Bob_prikey 是 Bob 的私鑰,自己存放。Bob_pubkey 是 Bob 的公鑰,交給 Bob。

Alice 發送信息給 Bob 時

使用 Bob 的公鑰加密: secret=rsa.encrypt(plain_byte,Bob_pubkey)。

Bob 接收到消息后

Bob 使用自己的私鑰,來對 Alice 發來的信息進行解密: plain=rsa.decrypt(secret,Bob_prikey).decode("utf-8")。

Bob 的公鑰可以讓 Alice 發消息給 Bob,Bob 用自己的私鑰揭秘。同樣,Alice 的密鑰對可以讓對方發消息給自己。至此,Alice 和 Bob 實現了安全的通信,他們用對方公鑰加密,用自己的私鑰解密發給自己的信息。

Alice 發給 Bob 的信息,即使被 Eve 截獲了,他也沒有 Bob 的私鑰,解不開密文。

但是,存在一個問題,如果 Eve 用 Bob 的公鑰加密信息,偽裝成 Alice 發個 Bob,這樣怎么辦呢?怎么確定 Alice 是 Alice 而不是 Eve 呢?問題的關鍵,在于 Alice 持有 Alice 私鑰,而 Eve 沒有私鑰,這是數字簽名技術的基礎。

六、真言:數字簽名

Eve 偽裝成 Alice,如同假唐僧偽裝成唐僧,言行舉止看起來很像,讓人怎么區分呢?很簡單,真唐僧有一個核心科技,那就是緊箍咒。

非對稱加密時,通常用公鑰加密,私鑰解密。如果用私鑰加密,其實相當與簽名了。因為只有私鑰持有者才能加密,且被公鑰解密。所以私鑰加密相當于私鑰持有者確認簽名——該消息來自私鑰持有人。

私鑰就相當于真唐僧的緊箍咒。

因為效率,一般不對原始信息進行加密,而是對其哈希之后的值進行加密。根據上文哈希的特性,這依然可以保證原始信息唯一、未篡改。

對消息摘要進行私鑰加密,稱為數字簽名。

驗證步驟如下:

Alice 準備發送信息 PlainText首先計算其 MD5 哈希值 Hash_a再對哈希值進行私鑰加密(數字簽名)發送 Alice 的公鑰,數字簽名,消息給 BobBob 收到信息后使用 Alice 的公鑰解密數字簽名,產生一個待驗證哈希值 Hash_a然后計算消息哈希值 Hash_b如果Hasha == Hashb,說明發送者必然是持有私鑰的 Alice ,且消息未修改否則,說明信息不是 Alice 發送的

signature = rsa.sign(plain_byte, Alice_prikey, "MD5")status = rsa.verify(plain_byte, signature, Alice_pubkey)

注意上例 sign 方法中簽名的是 Alice 的私鑰,而檢查時則使用 Alice 的公鑰。Alice 無法抵賴他簽名的信息,因為只有他持有自己的私鑰,別人無法簽名(私鑰加密)一個這樣的信息。

如同真唐僧會念緊箍咒,這就是他的私鑰。假唐僧看起來很像樣,但是他并不掌握緊箍咒,所以無法念動真言。

七、總結

本文用 20 行 Python 代碼來演示如何實現安全通信的功能。

哈希函數,是可以提取消息數字指紋的工具,他可以驗證數據完整性。

對稱加密簡單實用。

借助非對稱加密,我們實現了安全通信,而數字簽名使得對方無法偽裝或抵賴。

關鍵詞: 數字簽名 公鑰加密 怎么辦呢 安全通信 用自己的

上一篇:

下一篇:

X 關閉

X 關閉

久久国产精品一区二区三区四区,久色婷婷小香蕉久久,国产日韩欧美在线播放不卡,另类av一区二区
欧美破处大片在线视频| 尤物视频一区二区| 亚洲欧美一区二区三区在线| 在线日韩精品视频| 香蕉亚洲视频| 亚洲国产日韩精品| 韩国一区二区三区美女美女秀| 国产亚洲成av人片在线观看桃| 国产精品免费观看在线| 欧美日韩一区二区三区免费看| 国产视频一区二区三区在线观看| 国产欧美亚洲日本| 欧美一区二区免费观在线| 一本色道精品久久一区二区三区| 欧美理论视频| 欧美诱惑福利视频| 99pao成人国产永久免费视频| 亚洲精选在线| 亚洲欧美日产图| 久久狠狠亚洲综合| 国产精品极品美女粉嫩高清在线| 国产精品男女猛烈高潮激情| 欧美日韩三区四区| 国产精品制服诱惑| 欧美日韩国产黄| 久久不射电影网| 亚洲区第一页| 国内精品久久久久影院薰衣草| 1000部国产精品成人观看| 欧美另类在线观看| 亚洲电影免费| 国产精品多人| 欧美久久久久免费| 国产一区二区三区电影在线观看| 一区福利视频| 在线欧美日韩国产| 欧美一区二区三区另类| 91久久精品国产91性色tv| 免费欧美视频| 欧美午夜片欧美片在线观看| 欧美va日韩va| 欧美一区二区黄色| 欧美午夜a级限制福利片| 国产综合一区二区| 国产目拍亚洲精品99久久精品| 欧美日韩高清在线| 女人色偷偷aa久久天堂| 亚洲欧美一区二区三区在线| 午夜精品久久久久久久99樱桃| 亚洲精品在线免费| 国产亚洲综合在线| 伊人精品成人久久综合软件| 国产精品免费一区二区三区观看| 亚洲视频电影图片偷拍一区| 欧美va天堂| 欧美一区二区在线免费观看| 亚洲精品日日夜夜| 欧美va亚洲va日韩∨a综合色| 国产精品v日韩精品| 国产欧美精品日韩区二区麻豆天美| 一区视频在线| 久久精品中文字幕一区| 日韩一区二区免费高清| 久久久成人网| 久久免费国产精品| 欧美日韩国产首页在线观看| 国产亚洲成av人片在线观看桃| 久久国产精品高清| 欧美一级理论片| 久久激情视频久久| 久久国产日韩| 欧美久久一区| 欧美在线观看一二区| 国产视频在线观看一区二区三区| 久久亚洲综合色| 一区二区不卡在线视频 午夜欧美不卡在| 欧美日韩精品在线视频| 亚洲一区二区三区在线| 欧美日韩国产大片| 欧美不卡三区| 欧美日韩国产高清视频| 国产香蕉久久精品综合网| 伊人久久亚洲影院| 国产午夜精品视频免费不卡69堂| 欧美日韩在线免费观看| 久久综合久久美利坚合众国| 久久在线免费观看视频| 久久久久久91香蕉国产| 亚洲一区久久| 亚洲欧美一区二区三区极速播放| 久久综合九色九九| 久久久女女女女999久久| 鲁鲁狠狠狠7777一区二区| 欧美主播一区二区三区美女 久久精品人| 久久久精品国产一区二区三区| 国产精品久久国产三级国电话系列| 欧美三级乱码| 欧美国产综合视频| 欧美不卡激情三级在线观看| 国产精品久久久久久久7电影| 欧美片在线播放| 欧美高清视频在线| 久久婷婷国产综合国色天香| 日韩视频一区二区在线观看| 国产亚洲综合精品| 99视频在线精品国自产拍免费观看| 国产精品日韩一区| 亚洲黄一区二区三区| 国产亚洲aⅴaaaaaa毛片| 国产女人aaa级久久久级| 国产精品久久国产精品99gif| 亚洲精品国产品国语在线app| 亚洲性视频h| 老鸭窝91久久精品色噜噜导演| 激情综合久久| 亚洲网址在线| 欧美一二三区精品| 午夜在线一区| 激情综合色综合久久综合| 国产一区二区三区久久精品| 国产欧美高清| 国产精品久久国产精麻豆99网站| 久久精品免费| 欧美成人精品三级在线观看| 国产精品九色蝌蚪自拍| 欧美精品18videos性欧美| 国产欧美精品一区二区三区介绍| 欧美精品一区二区三区很污很色的| 国产精品天天摸av网| 欧美日韩中文在线| 欧美日韩亚洲一区二区三区在线观看| 欧美日韩日日夜夜| 欧美激情一区二区| 欧美日韩精品中文字幕| 国产欧美日韩中文字幕在线| 亚洲天堂av电影| 久久视频这里只有精品| 欧美日韩国内自拍| 在线不卡视频| 久久视频在线视频| 欧美日韩福利在线观看| 亚洲免费观看视频| 亚洲已满18点击进入久久| 午夜精品美女久久久久av福利| 欧美激情亚洲自拍| 国产一区二区三区不卡在线观看| 亚洲男人第一网站| 欧美一区二区视频观看视频| 欧美xxx在线观看| 欧美日韩色综合| 99视频超级精品| 欧美视频成人| 国产亚洲成年网址在线观看| 亚洲丁香婷深爱综合| 亚洲欧美日韩在线综合| 亚洲一区二区三区精品在线| 欧美日韩黄色一区二区| 国产区欧美区日韩区| 亚洲精品视频在线观看网站| 欧美激情视频网站| 国产精品久久久久久久久久ktv| 久久精品一区二区三区不卡| 欧美日韩午夜在线| 亚洲激精日韩激精欧美精品| 精品白丝av| 国产一区二区在线免费观看| 亚洲另类自拍| 国产精品少妇自拍| 国外视频精品毛片| 久久精品欧洲| 日韩视频一区二区三区在线播放免费观看| 亚洲国产精品一区在线观看不卡| 麻豆久久精品| 久久一区二区三区av| 亚洲大片精品永久免费| 国产精品视频在线观看| 亚洲欧美制服中文字幕| 99精品视频一区| 欧美日韩成人在线| 欧美阿v一级看视频| 一区二区三区成人| 国产视频在线观看一区二区三区| 午夜精品久久久久久久99樱桃| 国产精品毛片在线看| 亚洲一区精品在线| 在线日韩精品视频| 亚洲国产日韩欧美| 亚洲免费中文字幕| 欧美日韩成人精品| 亚洲激情视频| 农夫在线精品视频免费观看| 日韩一二三区视频| 国产精品视频第一区| 久久久国产一区二区| 午夜在线电影亚洲一区| 国产精品久久久久久久久免费| 国产精品免费看| 亚洲男人的天堂在线观看| 亚洲精品国产系列| 欧美欧美午夜aⅴ在线观看|