【python】Python中使用GCM加密模式

本人在java中運(yùn)行的一段AES加密代碼姚建,采用的是GCM加密模式坦报,出于某種原因需要將這部分代碼移植到python項(xiàng)目中去,但發(fā)現(xiàn)python自帶的加密庫(kù)中不支持GCM這一加密模式撑帖,經(jīng)過(guò)google之后铐炫,發(fā)現(xiàn)第三方加密庫(kù)pyca/cryptography支持,所以記錄下來(lái)

一习柠、GCM加密模式的介紹

GCM中的G就是指GMAC匀谣,C就是指CTR。

GCM可以提供對(duì)消息的加密和完整性校驗(yàn)资溃,另外武翎,它還可以提供附加消息的完整性校驗(yàn)。在實(shí)際應(yīng)用場(chǎng)景中溶锭,有些信息是我們不需要保密宝恶,但信息的接收者需要確認(rèn)它的真實(shí)性的,例如源IP趴捅,源端口垫毙,目的IP,IV拱绑,等等综芥。因此,我們可以將這一部分作為附加消息加入到MAC值的計(jì)算當(dāng)中猎拨。下圖的Ek表示用對(duì)稱秘鑰k對(duì)輸入做AES運(yùn)算膀藐。最后,密文接收者會(huì)收到密文红省、IV(計(jì)數(shù)器CTR的初始值)额各、MAC值。

image

(以上介紹原文鏈接:https://blog.csdn.net/T0mato_/article/details/53160772

之所以選用GCM吧恃,也就是因?yàn)樗瘸S玫腃BC加密模式更加安全和完善虾啦,以后建議同學(xué)們新開發(fā)的軟件可以考慮采用這種方式

二、Python(3)實(shí)現(xiàn)

1痕寓、安裝cryptography


pip install cryptography

2缸逃、代碼實(shí)現(xiàn)

import os
from cryptography.hazmat.backendsimport default_backend
from cryptography.hazmat.primitives.ciphersimport (
Cipher, algorithms, modes
)

def encrypt(key, plaintext):
  iv = os.urandom(12)

  encryptor = Cipher(
        algorithms.AES(key),
        modes.GCM(iv),
        backend=default_backend()
  ).encryptor()

  ciphertext = encryptor.update(plaintext) + encryptor.finalize() + encryptor.tag #將tag直接追加在最后,即可和java解密代碼兼容
  return ciphertext.hex().upper()

if __name__ =='__main__':
    key = os.urandom(32)
    ciphertext = encrypt(key, b"a secret message!")
    print(ciphertext)

以上代碼僅作參考厂抽,更多詳細(xì)內(nèi)容可移至此處學(xué)習(xí):https://cryptography.io/en/latest/hazmat/primitives/symmetric-encryption/#cryptography.hazmat.primitives.ciphers.modes.GCM

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市丁眼,隨后出現(xiàn)的幾起案子筷凤,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 221,430評(píng)論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件藐守,死亡現(xiàn)場(chǎng)離奇詭異挪丢,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)卢厂,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,406評(píng)論 3 398
  • 文/潘曉璐 我一進(jìn)店門乾蓬,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人慎恒,你說(shuō)我怎么就攤上這事任内。” “怎么了融柬?”我有些...
    開封第一講書人閱讀 167,834評(píng)論 0 360
  • 文/不壞的土叔 我叫張陵死嗦,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我粒氧,道長(zhǎng)越除,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 59,543評(píng)論 1 296
  • 正文 為了忘掉前任外盯,我火速辦了婚禮摘盆,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘饱苟。我一直安慰自己孩擂,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 68,547評(píng)論 6 397
  • 文/花漫 我一把揭開白布掷空。 她就那樣靜靜地躺著肋殴,像睡著了一般。 火紅的嫁衣襯著肌膚如雪坦弟。 梳的紋絲不亂的頭發(fā)上护锤,一...
    開封第一講書人閱讀 52,196評(píng)論 1 308
  • 那天,我揣著相機(jī)與錄音酿傍,去河邊找鬼烙懦。 笑死,一個(gè)胖子當(dāng)著我的面吹牛赤炒,可吹牛的內(nèi)容都是我干的氯析。 我是一名探鬼主播,決...
    沈念sama閱讀 40,776評(píng)論 3 421
  • 文/蒼蘭香墨 我猛地睜開眼莺褒,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼掩缓!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起遵岩,我...
    開封第一講書人閱讀 39,671評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤你辣,失蹤者是張志新(化名)和其女友劉穎巡通,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體舍哄,經(jīng)...
    沈念sama閱讀 46,221評(píng)論 1 320
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡宴凉,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,303評(píng)論 3 340
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了表悬。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片弥锄。...
    茶點(diǎn)故事閱讀 40,444評(píng)論 1 352
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖蟆沫,靈堂內(nèi)的尸體忽然破棺而出籽暇,到底是詐尸還是另有隱情,我是刑警寧澤饥追,帶...
    沈念sama閱讀 36,134評(píng)論 5 350
  • 正文 年R本政府宣布图仓,位于F島的核電站,受9級(jí)特大地震影響但绕,放射性物質(zhì)發(fā)生泄漏救崔。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,810評(píng)論 3 333
  • 文/蒙蒙 一捏顺、第九天 我趴在偏房一處隱蔽的房頂上張望六孵。 院中可真熱鬧,春花似錦幅骄、人聲如沸劫窒。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,285評(píng)論 0 24
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)主巍。三九已至,卻和暖如春挪凑,著一層夾襖步出監(jiān)牢的瞬間孕索,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,399評(píng)論 1 272
  • 我被黑心中介騙來(lái)泰國(guó)打工躏碳, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留搞旭,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 48,837評(píng)論 3 376
  • 正文 我出身青樓菇绵,卻偏偏與公主長(zhǎng)得像肄渗,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子咬最,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,455評(píng)論 2 359

推薦閱讀更多精彩內(nèi)容