《密碼學(xué)基礎(chǔ)》全套教學(xué)課件_第1頁
《密碼學(xué)基礎(chǔ)》全套教學(xué)課件_第2頁
《密碼學(xué)基礎(chǔ)》全套教學(xué)課件_第3頁
《密碼學(xué)基礎(chǔ)》全套教學(xué)課件_第4頁
《密碼學(xué)基礎(chǔ)》全套教學(xué)課件_第5頁
已閱讀5頁,還剩232頁未讀 繼續(xù)免費閱讀

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認領(lǐng)

文檔簡介

——密碼的歷史及古典密碼傳統(tǒng)加密技術(shù)4學(xué)時第1章

古典密碼第2章分組密碼與DES第3章AES第4章

序列密碼第5章公鑰密碼與RSA第6章

數(shù)字簽名第7章消息認證與Hash函數(shù)全套可編輯PPT課件密碼的起源和發(fā)展密碼學(xué)的基本概念古典密碼初等密碼分析主要內(nèi)容全套可編輯PPT課件了解密碼的產(chǎn)生和發(fā)展歷史掌握密碼學(xué)的基本概念理解古典密碼的加密思想,掌握基本的加密方法:置換和代替掌握密碼體制的分類方法理解初等密碼分析的思想教學(xué)目的全套可編輯PPT課件古代——近代——現(xiàn)代

一、密碼的起源和發(fā)展19491976全套可編輯PPT課件隱寫術(shù)Staganography

由希臘詞Steganos(覆蓋)和Graphein(寫)派生而來。密碼術(shù)Cryptography

由希臘詞Kryptos(隱藏)派生而來。密碼的起源希波戰(zhàn)爭,漏格板希斯塔亞烏斯,在奴隸頭皮上寫字中國古代,蠟封小球公元一世紀,普林尼,隱形墨水一、密碼的起源和發(fā)展密碼技術(shù)的發(fā)展15世紀,意大利建筑師利昂.阿爾伯提設(shè)計的密碼盤密碼技術(shù)的發(fā)展?jié)摲嚓P(guān)影視作品例:

愷撒《高盧記》——將羅馬字母用希臘字母替換蘇托尼厄斯《愷撒傳》——愷撒密碼一、密碼的起源和發(fā)展兩種基本加密方法代替——對標準書寫符號的修改Substitution機械密碼大行其道Enigma,Hagelin密碼機密碼破譯成果輝煌紫密,圖靈炸彈,中途島新技術(shù)的大量使用微粒照片,圖靈機一、密碼的起源和發(fā)展二戰(zhàn)中的密碼特點機械密碼:用機器實現(xiàn)代替與置換三種有代表性的密碼機:

Enigma(德、意、日軍方)

Lorenz(德國高層)Hagelin(盟國:美、英、法等)

二戰(zhàn)中的密碼一、密碼的起源和發(fā)展三、古典密碼(Classical

Ciphers)Enigma三、古典密碼(Classical

Ciphers)Hagelin1912年,美國人愛德華.休.赫本(EdwardHughHebern)發(fā)明了可以通過”移動字母板”加密的打字機,并申請專利。1918年,德國人阿瑟.謝爾比斯為Enigma申請專利。瑞典人鮑里斯.愷撒.威廉.哈格林(BorisCaesarWilhelmHagelin),靠密碼機發(fā)財?shù)谝蝗?/p>

三、古典密碼(Classical

Ciphers)機械密碼轉(zhuǎn)輪機(RotorMachine)

大量裝備、參加實戰(zhàn)、遭到破譯、徹底曝光

1918年,德國發(fā)明家阿瑟.謝爾比斯為Enigma申請專利,并與理查德.里特建立了謝爾比斯&里特公司,出售Enigma,售價為今天的3萬$/臺困境:賣不出去采取措施:拼命改進轉(zhuǎn)機:1922年,丘吉爾出版《第一次世界大戰(zhàn)回憶錄》

Enigma納粹德國的四大軍事象征

普魯士之鷹鐵十字EnigmaEnigma英國組織破譯(布萊切利莊園)圖靈發(fā)明BombeEnigma破譯Enigma的意義:波蘭人,Bomba,機械化密碼分析時代的到來英國Bombe,證明了機械化密碼分析手段在破解機械化密碼時的極端必要性波蘭和英國專家能手工破譯,說明了密碼破譯歸根結(jié)底是人類智慧的勝利。Enigma密碼學(xué)(Cryptology):

研究信息系統(tǒng)安全保密的科學(xué),包括密碼編碼學(xué)和密碼分析學(xué)。密碼編碼學(xué)(Cryptography):

主要研究對信息進行編碼,實現(xiàn)對信息的隱蔽.密碼分析學(xué)(Cryptanalytics):主要研究加密消息的破譯或消息的偽造.二、密碼學(xué)的基本概念密碼體制:是一個五元組(P,C,K,E,D),滿足條件:(1)P是可能明文的有限集(明文空間)(2)C是可能密文的有限集(密文空間)(3)K是一切可能密鑰構(gòu)成的有限集(密鑰空間)(4)任意k∈K,有一個加密算法ek∈E和相應(yīng)的解密算法dk∈D,使得ek:P→C和dk:C→P分別為加密解密函數(shù),滿足dk(ek(x))=x,這里x∈P。二、密碼學(xué)的基本概念密碼體制Example明文:Allofgaulisdividedintothreeparts.密文:DOORIJEXOLVGLYLGHGLQWRWKUHHSDUWV代替密碼2.單表代替(MonoalphabeticSubstitution)所有的消息用同一個代替表加密,相同的明文替換為相同的密文。例:

乘法密碼 仿射密碼,多項式代替密碼 密鑰短語密碼(將口令字中的字符無重復(fù)地寫下,再將余下的字符按順序?qū)懞茫⑺鼈兒兔魑淖帜附⒁灰粚?yīng)的關(guān)系。)三、古典密碼(Classical

Ciphers)代替密碼多表代替:1412年,埃及數(shù)學(xué)家艾哈邁德.卡勒卡尚迪(Ahmadal-Qalqashandi)在百科全書中第一次提出。1508年,德國修道院院長約翰內(nèi)斯.特米特里烏斯(HohannesTrithemius)首先構(gòu)造出方表(tableau)——多個代替表1553年,意大利學(xué)者吉奧萬.巴蒂斯塔.貝拉索(GiovanBattistaBellaso)設(shè)計出了密鑰。貝拉索密碼,使用時間較長,美國內(nèi)戰(zhàn)時北軍使用。多表代替1586年,法國外交官布萊斯.德.維吉尼亞(BlaiseDeVigenere)對貝拉索密碼進行改良。Vigenère密碼:1854年,被英國人查理斯.巴貝奇(CharlesBabbage)所破譯查理斯.巴貝奇(1792-1871):設(shè)計了差分機(differenceengine)和分析機(analyticalengine),是現(xiàn)代計算機的雛形。多表代替二、置換技術(shù)(Permutation)1.柵欄技術(shù)——按列寫入,按行讀出。例:用深度為2的柵欄技術(shù)加密明文“meetmeaftertheparty”

可寫為按行讀出密文為“mematrhtgpryetefeteoaat”2.矩陣密碼——把消息按行寫入,再按列讀出。mematrhtgpryetefeteoaat三、古典密碼(Classical

Ciphers)置換密碼加密部分可分為:多表代替模塊:轉(zhuǎn)輪組單表代替模塊:連接板附加模塊:反射板Enigma破譯或攻擊(Break/Attack)密碼的方法包括窮舉破譯法(ExhaustiveAttack)和分析法兩類。窮舉法,又稱為強力攻擊(Brute-forceMethod),指對截收的密文依次用各種可能的密鑰試譯,直到得到有意義的明文;或者在不變密鑰下,對所有可能的明文加密直到得到與截獲密文一致,這又稱為完全試湊法(CompleteTrial-and-errorMethod)四、初等密碼分析唯密文攻擊(CiphertectOnlyAttak)分析者從僅知道的密文進行分析,試圖得出明文或密鑰。已知明文攻擊(KnowPlaintextAttak)分析者除了有截獲密文外,還有一些已知的明文-密文對。選擇明文攻擊(ChosenPlaintextAttack)分析者可以選定任何明文-密文對進行攻擊,以確定未知密鑰。選擇密文攻擊(ChosenCiphertextAttack)分析者可以利用解密機由他所選的密文解密出相應(yīng)明文,以確定未知密鑰。四、初等密碼分析密碼分析分類分組密碼與數(shù)據(jù)加密標準4學(xué)時分組密碼的基本概念數(shù)據(jù)加密標準DESDES的產(chǎn)生及使用DES算法細節(jié)DES的安全性分析DES在設(shè)計上的優(yōu)點分組密碼的設(shè)計原理分組密碼的工作方式主要內(nèi)容現(xiàn)代密碼對稱密碼非對稱密碼序列密碼分組密碼對稱密碼非對稱密碼現(xiàn)代密碼的分類加密方式序列密碼(Streamcipher):也叫流密碼,用隨機的密鑰序列依次對明文字符加密,一次加密一個字符。分組密碼(Blockcipher):將明文劃分為長度固定的組,逐組進行加密,得到長度固定的一組密文。密文分組中的每一個字符與明文分組的每一個字符都有關(guān)。第一節(jié)分組密碼的基本概念加密算法解密算法明文密鑰密鑰x=(x1,…,xm

)y=(y1,…,yn

)密文第一節(jié)分組密碼的基本概念分組密碼加密框圖分組長度:64bit有效密鑰長度:56bit密鑰生成算法:產(chǎn)生16個48bit的子密鑰解密過程與加密過程相同,所使用的密鑰也相同,但各個子密鑰的使用順序不同。算法的全部的細節(jié)公開,安全性完全依賴于密鑰。第二節(jié)數(shù)據(jù)加密標準DESDES基本特征初始置換IP16輪迭代逆初始置換IP-1子密鑰產(chǎn)生算法。

第二節(jié)數(shù)據(jù)加密標準DESDES算法細節(jié)算法構(gòu)成對64bit的明文重新排列,而后分成左右兩段,每段32bit,以L0和R0表示。IP中各列元素位置號數(shù)相差為8,相當于將原明文各字節(jié)按列寫出,各列比特經(jīng)過偶采樣和奇采樣置換后,再對各行進行逆序排列,將陣中元素按行讀出,構(gòu)成置換的輸出。第二節(jié)數(shù)據(jù)加密標準DES初始置換IP在16圈迭代之后,將左右兩段合并為64bit,進行置換IP-1,得到輸出的64bit密文。第二節(jié)數(shù)據(jù)加密標準DES逆初始置換IP和IP-1的輸入與輸出是已知的一一對應(yīng)關(guān)系作用:打亂原來輸入的ASCII碼字劃分,并將原來明文的校驗位(如果有的話)變?yōu)镮P輸出的一個字節(jié)。第二節(jié)數(shù)據(jù)加密標準DES逆初始置換將經(jīng)過IP置換后的數(shù)據(jù)分成32bit的左右兩段,進行16圈迭代每次迭代只對右邊的32bit進行一系列的加密變換一輪迭代即將結(jié)束時,將左邊的32bit與右邊進行變換后得到的32bit按位模2加,作為下一輪迭代時右邊的段,并將原來右邊未經(jīng)變換的段直接作為下一輪迭代時左邊的段。

第二節(jié)數(shù)據(jù)加密標準DES乘積變換——DES算法的核心64比特初始密鑰經(jīng)過置換選擇PC-1循環(huán)移位置換選擇PC-2產(chǎn)生16次迭代所用的子密鑰ki

初始密鑰的第8、16、24、32、40、48、56、64位為奇偶校驗位,其余56位為有效位,PC-1的目的是從64位中選出56位有效位。第二節(jié)數(shù)據(jù)加密標準DES子密鑰生成算法每次移位后,將C和D中的原存數(shù)送給置換選擇PC-2,PC-2將C中第9、18、22、25位和D中第7、9、15、26位刪去,將其余數(shù)字置換位置,輸出48比特,作為子密鑰。第二節(jié)數(shù)據(jù)加密標準DES子密鑰生成IP:初始置換ki

:第i次迭代所用的子密鑰Li、Ri:第i次迭代時左邊和右邊的32比特f:每次迭代時對右邊所作的變換:逐位模2加。

第二節(jié)數(shù)據(jù)加密標準DESDES算法的數(shù)學(xué)表示符號說明加密過程:64Bit明文64Bit密文(1)(2)第二節(jié)數(shù)據(jù)加密標準DESDES算法的數(shù)學(xué)表示解密過程:(64比特明文)(64比特密文)第二節(jié)數(shù)據(jù)加密標準DESDES算法的數(shù)學(xué)表示互補對稱性弱密鑰和半弱密鑰對DES的強力攻擊差分分析和線性分析第二節(jié)數(shù)據(jù)加密標準DESDES的安全性DES設(shè)計上的優(yōu)點主要體現(xiàn)在以下幾個方面循環(huán)次數(shù)雪崩準則精巧的S盒和P盒第二節(jié)數(shù)據(jù)加密標準DESDES在設(shè)計上的優(yōu)點電子密碼本ECB(electroniccodebookmode)密碼分組鏈接CBC(cipherblockchaining)密碼反饋CFB(cipherfeedback)輸出反饋OFB(outputfeedback)第四節(jié)分組密碼的工作方式第四節(jié)分組密碼的工作方式分組密碼的加密方式和設(shè)計準則DES算法的基本結(jié)構(gòu),非線性運算DES的安全性及設(shè)計上的優(yōu)點分組密碼的設(shè)計原理及Feistel模型分組密碼的四種工作方式第二節(jié)數(shù)據(jù)加密標準DES小結(jié)高級加密標準4學(xué)時AES概述Rijndael加密算法主要內(nèi)容了解高級加密標準的設(shè)計思想掌握AES算法的運算過程教學(xué)目的1997年4月15日,(美國)國家標準技術(shù)研究所(NIST)發(fā)起征集高級加密標準AES的活動,目的是確定一個非保密的、可以公開技術(shù)細節(jié)的、全球免費使用的分組密碼算法,作為新的數(shù)據(jù)加密標準。1997年9月12日,美國聯(lián)邦登記處公布了正式征集AES候選算法的通告。第一節(jié)AES

概述第一節(jié)AES概述對AES的基本要求:比三重DES快至少與三重DES一樣安全數(shù)據(jù)分組長度為128比特密鑰長度為128/192/256比特。AESBackground第一節(jié)AES

概述1998年8月,首屆AES會議,指定15個候選算法。1999年3月22日,第二次AES會議,候選名單減少為5個:RC6,Rijndael,SERPENT,Twofish和MARS。2000年4月13日,第三次AES會議,對這5個候選算法的各種分析結(jié)果進行了討論。2000年10月2日,NIST宣布了獲勝者—Rijndael算法,2001年11月出版了最終標準FIPSPUB197。AESBackground第一節(jié)AES

概述Rijndael加解密過程第六節(jié)高級加密標準AES唯一的非線性運算,代替表(S盒)可逆,由兩個變換構(gòu)成:首先在GF(28)中模m(x)取乘法逆,m(x)=x8+x4+x3+x+1,0映射到自身;然后經(jīng)過一個仿射變換字節(jié)代替(Bytesub)第二節(jié)Rijndael加密算法逆運算(InvByteSub)先經(jīng)過仿射變換的逆變換作用之后,再在GF(28)中模m(x)取乘法逆。字節(jié)代替(Bytesub)第二節(jié)Rijndael加密算法行移位(ShiftRow)第二節(jié)Rijndael加密算法狀態(tài)行移位不同的位移量第0行不移動第1行循環(huán)左移C1字節(jié)第2行循環(huán)左移C2字節(jié)第3行循環(huán)左移C3字節(jié),逆運算(InvShiftRow)

后面3行分別循環(huán)左移:

Nb-C1字節(jié)

Nb-C2字節(jié)

Nb-C3字節(jié)行移位(ShiftRow)第二節(jié)Rijndael加密算法Rijndael加密程序S=B⊕K0;Fori=1toNr-1 S=ByteSub(S);

S=ShiftRow(S);

S=MixColumn(S);

S=Ki⊕S;S=ByteSub(S);S=ShiftRow(S);S=KNrS;Rijndael算法第二節(jié)Rijndael加密算法注:最后一圈無列混合Rijndael解密程序S=KNr⊕C;S=InvShiftRow(S);S=InvByteSub(S);S=KNr⊕

S;Fori=Nr-1to1 S=KiS;

S=InvMixColumn(S);

S=InvShiftRow(S);

S=ByteSub(S);

S=K0⊕S;Rijndael算法第二節(jié)Rijndael加密算法將16字節(jié)初始密鑰擴展為156字節(jié)(44字)的擴展密鑰;擴展密鑰的前四個字直接由輸入密鑰中復(fù)制,即w[0]~w[3];w[i]的值依賴于w[i-1]和w[i-4]密鑰擴展算法第二節(jié)Rijndael加密算法(迭代圈數(shù)為10時)對于下標為4的倍數(shù)的密鑰字,其產(chǎn)生方法更為復(fù)雜,表示為函數(shù)g包括的運算步驟有:字循環(huán)(RotWord):使一個字中的4個字節(jié)循環(huán)左移一個字節(jié)字節(jié)代換(SubWord):利用S盒對輸入字中的每個字節(jié)進行代替字循環(huán)與字節(jié)代換的結(jié)果再與輪常量Rcon[j]相異或密鑰擴展算法第二節(jié)Rijndael加密算法無弱密鑰或補密鑰能有效抵抗差分分析和線性分析迭代圈數(shù)大于6時可抗截斷差分分析圈數(shù)大于7時可抗Square攻擊密鑰量大,窮舉攻擊較困難Rijndael的安全性第二節(jié)Rijndael加密算法第一節(jié)序列的隨機性2學(xué)時第四章序列的隨機性隨機性的概念及參數(shù)隨機性假設(shè)偽隨機數(shù)發(fā)生器線性同余發(fā)生器用密碼編碼產(chǎn)生隨機數(shù)BBS發(fā)生器主要內(nèi)容掌握隨機性的含義及衡量方法理解隨機性假設(shè)的含義掌握線性同余發(fā)生器的原理及參數(shù)選擇理解如何用密碼產(chǎn)生隨機數(shù)理解BBS發(fā)生器的原理教學(xué)目的隨機序列:不能重復(fù)產(chǎn)生的序列幾個相關(guān)概念真隨機——不能重復(fù)產(chǎn)生密碼學(xué)意義上的隨機——不能預(yù)測偽隨機——看起來是隨機的,并能通過許多隨機性測試第一節(jié)序列的隨機性真隨機數(shù)發(fā)生器(TRNG):利用物理方法實現(xiàn)的隨機數(shù)發(fā)生器,它是自然界隨機的物理過程(所產(chǎn)生物理現(xiàn)象的不確定性)的反映,即使算法等重要信息被暴露,都無法猜測其結(jié)果如何產(chǎn)生真隨機數(shù)1.若序列的周期為偶數(shù),則在一個周期內(nèi),0、1的個數(shù)相等;若周期為奇數(shù),則在一個周期內(nèi),0、1的個數(shù)相差1。2.在一個周期內(nèi),長度為l的游程數(shù)占游程總數(shù)的1/2l,且對于任意長度,0游程與1游程個數(shù)相等。3.所有異相自相關(guān)函數(shù)值相等。Golomb隨機性假設(shè)第一節(jié)序列的隨機性偽隨機數(shù)發(fā)生器——將一個短的隨機數(shù)“種子”擴展為較長的偽隨機序列的確定算法。線性同余發(fā)生器(Linearcongruentialgenerator)用加密方式產(chǎn)生隨機數(shù)BBS發(fā)生器偽隨機數(shù)發(fā)生器第一節(jié)序列的隨機性評價線性同余發(fā)生器有以下準則:(1)完整周期:即在一個周期中,0至m-1之間的數(shù)都出現(xiàn)。(2)滿足隨機性測試。(3)可以高效地實現(xiàn)。線性同余法的優(yōu)點:方便,快速;缺點:除初值外,其它數(shù)字都用確定算法產(chǎn)生。第一節(jié)序列的隨機性線性同余發(fā)生器線性同余發(fā)生器先后被JimReeds和JoanBoyar破譯后者還破譯了二次同余發(fā)生器Xn=(ax2n-1+bxn+c)modm和三次同余發(fā)生器Xn=ax3n-1+bx2n-1+cxn-1+d線性同余發(fā)生器NIST為銀行電子支付系統(tǒng)建議的標準算法,被PGP采納,在Internet中使用。方法:用三重DES的EDE模式產(chǎn)生,使用兩個密鑰K1,K2兩個驅(qū)動隨機數(shù):初始化時,設(shè)DT0為初始時刻的日期和時間(64bit),V0為種子密鑰(64bit)輸出:64bit的隨機數(shù)Ri和更新后的Vi+1偽隨機數(shù)發(fā)生器第一節(jié)序列的隨機性(3)ANSIX9.17偽隨機數(shù)產(chǎn)生器

每一時刻要進行三次加密,相當于9次DES加密,由兩個偽隨機數(shù)驅(qū)動。偽隨機數(shù)發(fā)生器第一節(jié)序列的隨機性用K1,K2對DT0加密,結(jié)果與V0相加,再對其加密,得到R0BlumBlumShub產(chǎn)生器(BBS發(fā)生器):

利用數(shù)論方法產(chǎn)生偽隨機數(shù)選擇兩個大素數(shù)p,q,滿足p≡q≡3mod4;計算其乘積n=pq;選擇隨機數(shù)s,(s,n)=1;通過以下公式迭代計算序列{Bi}偽隨機數(shù)發(fā)生器第一節(jié)序列的隨機性BBS發(fā)生器在密碼學(xué)意義上是相對安全的,但計算量比較大。偽隨機數(shù)發(fā)生器第一節(jié)序列的隨機性第二節(jié)序列密碼的原理2學(xué)時序列密碼的基本概念加密方式密鑰序列生成器線性反饋移位寄存器與m序列線性反饋移位寄存器移位寄存器的周期及m序列序列的線性復(fù)雜度與B-M算法主要內(nèi)容明文符號序列與密鑰符號序列逐個加密密鑰序列z=z1z2…的第i個符號加密明文序列m=m1m2…的第i個符號,即若密鑰序列重復(fù)使用,則稱為周期序列密碼,否則,就是一次一密密碼。序列密碼的加密方式第二節(jié)序列密碼的基本概念由密鑰流生成器生成第i個密鑰取決于第i時刻密鑰生成器的內(nèi)部狀態(tài)和初始密鑰。對序列密碼的安全性有兩個基本要求:根據(jù)密鑰序列以前的狀態(tài),不能很容易地推導(dǎo)出后續(xù)狀態(tài),即密鑰序列要有足夠高的隨機性;傳輸密鑰的秘密信道必須足夠安全。序列密碼中的密鑰密碼的安全性主要取決于所用密鑰的隨機性,所以設(shè)計序列密碼的核心問題是設(shè)計隨機性較好的密鑰流生成器設(shè)計密鑰流生成器的關(guān)鍵:尋找狀態(tài)轉(zhuǎn)移函數(shù)和輸出函數(shù),使輸出的密鑰序列有良好的偽隨機性。密鑰流生成器第二節(jié)序列密碼的基本概念Rueppel將密鑰流生成器分為兩部分:驅(qū)動部分和非線性組合部分。驅(qū)動部分控制生成器的狀態(tài),并為非線性組合部分提供周期長、統(tǒng)計性能良好的序列;非線性組合部分利用這些序列組合出滿足要求的密鑰序列。密鑰流生成器第二節(jié)序列密碼的基本概念根據(jù)密鑰序列的產(chǎn)生方法,可將序列密碼可分為兩類:同步序列密碼(SynchronousStreamCipher):狀態(tài)轉(zhuǎn)移函數(shù)與明文字符無關(guān)自同步序列密碼(Self-SynchronousStreamCipher):狀態(tài)轉(zhuǎn)移函數(shù)與明文字符相關(guān)。在同步流密碼中,只要發(fā)送端和接收端有相同的種子或?qū)嶋H密鑰和內(nèi)部狀態(tài),就能產(chǎn)生出相同的密鑰流,此時,認為發(fā)送端和接收端的密鑰生成器是同步的。序列密碼的分類第二節(jié)序列密碼的基本概念衡量密碼體制安全性的方法計算安全性(computationalsecurity),又稱實際安全性(practicalsecrecy):利用已有的最好的方法破譯該系統(tǒng)所需要的努力超過了敵手的破譯能力??勺C明安全性(provablesecurity):能用嚴格的數(shù)學(xué)方法證明破譯該體制等價于某個困難問題。無條件安全性(unconditionalsecurity)或完善保密性(perfectsecrecy):在信息論意義上是安全的。理論保密的密碼體制定理若某一密碼系統(tǒng)的明文數(shù)、密文數(shù)和密鑰數(shù)都相等,則該密碼體制完全保密的充要條件是:將某一明文加密成某一密文的密鑰只能有一個;所有密鑰都是等概率的。理論保密的密碼體制組成:一系列存儲單元、若干個乘法器和加法器通過電路連接而成。假設(shè)共有n個存儲單元(此時稱該移位寄存器為n級),每個存儲單元可存儲一比特信息,在第i時刻各個存儲單元中的比特序列(aiai+1…ai+n-1)稱為移位寄存器的狀態(tài),為初始狀態(tài)。線性反饋移位寄存器第三節(jié)線性反饋移位寄存器與m序列給定初態(tài)(101),按照反饋函數(shù)可求出各個時刻的狀態(tài)及輸出.狀態(tài)在第5時刻開始重復(fù),因此輸出序列的周期是4,輸出序列為1011101110111011……線性反饋移位寄存器(LFSR)第三節(jié)線性反饋移位寄存器與m序列定理5-1

n級LFSR的周期≤2n-1證明:n級LFSR最多有2n種不同狀態(tài),若初態(tài)為全零,則其后續(xù)狀態(tài)恒為零,構(gòu)成一個平凡序列,若初態(tài)不為零,則一個周期中最多出現(xiàn)2n-1種非零狀態(tài),故狀態(tài)周期小于等于2n-1,同樣,輸出序列的周期也小于等于2n-1。定義5-1周期為2n-1的n級LFSR的輸出序列稱為m序列。移位寄存器的周期及m序列第三節(jié)線性反饋移位寄存器與m序列序列的隨機性隨機性的含義偽隨機數(shù)發(fā)生器序列密碼的基本概念LFSR及m序列小結(jié)公鑰密碼學(xué)與RSA6學(xué)時第五章對稱密碼的弱點及公鑰密碼的原理MH背包公鑰密碼Diffie-Hellman密鑰交換RSA密碼主要內(nèi)容密鑰量大密鑰管理困難:傳遞、換發(fā)、保存無法實現(xiàn)網(wǎng)絡(luò)中的簽名、認證等應(yīng)用對稱密碼的弱點第一節(jié)公鑰密碼的原理密鑰量大對稱密碼的弱點設(shè)系統(tǒng)中共有n個用戶,兩兩進行保密通信,總共需要多少個密鑰?當n=5時,C(5,2)=10當n=1000時,C(1000,2)=499500密鑰量大對稱密碼的弱點設(shè)系統(tǒng)中共有n個用戶,兩兩進行保密通信,每個用戶有多少個密鑰?n-1個密鑰管理困難對稱密碼的弱點對稱密碼的弱點無法適應(yīng)網(wǎng)絡(luò)應(yīng)用數(shù)字簽名身份認證消息認證公鑰密碼的原理基本原理使用兩個不同的密鑰,一個用于加密,一個用于解密用于加密的密鑰Ek可以公開,用于解密的密鑰Dk保密Ek與Dk之間有聯(lián)系,但不能由Ek很容易地算出Dk公鑰密碼的原理加密與解密公鑰密碼的原理c=Ek(m)m=Dk(c)公鑰密碼的優(yōu)點密鑰數(shù)量大大減少密鑰管理方便公鑰密碼的原理公鑰密碼的安全性公鑰密碼的原理計算復(fù)雜性理論公鑰密碼的原理如何構(gòu)造陷門單向函數(shù):利用困難問題背包問題離散對數(shù)問題整數(shù)分解問題橢圓曲線離散對數(shù)問題公鑰密碼的原理典型公鑰密碼背包密碼RSA密碼Rabin密碼ElGamal密碼橢圓曲線密碼背包密碼1978年,Merkle和Hellman提出了基于背包問題的公鑰密碼體制。如何解決背包問題:窮舉法背包問題當物品個數(shù)為100時,有2100≈1.27×1030種可能性。把全世界所有的5億臺計算機全部聯(lián)網(wǎng)來求解這個問題,需要1000萬年!

背包密碼的安全性破譯方法: Shamir方法 L3格基歸約方法:由AKLenstra,HWLenstra&LLovasz提出

Lagarias-Odlyzko-Brickell的方法Diffie-Hellman密鑰交換功能:在沒有秘密信道的情況下,讓兩個用戶共享一個秘密密鑰理論基礎(chǔ):離散對數(shù)問題方法:利用用戶的公鑰和私鑰Diffie-Hellman密鑰交換計算Diffie-Hellman問題(CDH問題):已知ga和gb,計算gab如果CDH問題是容易的,則gab可以由p,g,ga,gb計算得到。背景數(shù)學(xué)基礎(chǔ)加密解密過程安全性及應(yīng)用第二節(jié)RSA密碼復(fù)習(xí):歐拉定理

如果a,n互素,則有a

Ф(n)≡1modn設(shè)n=pq,p,q均為素數(shù),且a,n互素,則Ф(n)=(p-1)(q-1)aФ(n)=a

(p-1)(q-1)≡1modn

第二節(jié)RSA密碼

選擇p,qp,q均為素數(shù)且p≠q

計算n=pq

計算Ф(n)=(p-1)(q-1)

選擇e1<e<Ф(n)且gcd(e,Ф(n))=1

計算dd≡e-1modФ(n)

公開n,e

保密d系統(tǒng)構(gòu)造對明文m=374加密計算c≡memodn≡37431mod2173=446解密:計算cd≡446671mod2173=374RSA:Example選擇p=53,q=41,n=pq=2173,Ф(n)=2080選擇e=31,計算出d=671將n,e公開,d保密加密:模冪運算解密:模冪運算正確性:歐拉定理安全性:分解大整數(shù)參數(shù)選擇RSA小結(jié)數(shù)字簽名4學(xué)時第六章

數(shù)字簽名的概念數(shù)字簽名與手寫簽名的區(qū)別數(shù)字簽名的特征

數(shù)字簽名的原理數(shù)字簽名分類

直接數(shù)字簽名仲裁數(shù)字簽名主要內(nèi)容數(shù)字簽名(DigitalSignature):以電子化形式,使用密碼方法,在數(shù)字消息中嵌入一個秘密信息,以驗證這個秘密信息是否正確來達到識別的目的,其實質(zhì)是一種密碼變換。第一節(jié)數(shù)字簽名概述手寫簽名的特點:

(1)簽名不可偽造。簽名中包含了簽名者個人所特有的一些信息,如寫字習(xí)慣、運筆方法等,是別人很難仿造的。

(2)簽名不可重用。一個簽名只能對一份文件起作用,不可能移到別的不同的文件上。第一節(jié)數(shù)字簽名概述手寫簽名

(3)文件內(nèi)容不可改變。在文件簽名后,文件的內(nèi)容就不能再變。

(4)簽名不可抵賴。簽名和文件都是物理的實體,簽名者不能在簽名后還聲稱他沒簽過名。手寫簽名應(yīng)用:網(wǎng)絡(luò)中的身份認證和消息認證。特征:

(1)不可否認性:簽名者事后不能否認。

(2)可驗證性:接收者能驗證簽名,而任何其他人都不能偽造簽名。

(3)可仲裁性:當雙方發(fā)生爭執(zhí)時,可以由一個公正的第三方出面解決爭端。第一節(jié)數(shù)字簽名概述數(shù)字簽名的特征構(gòu)成:簽名者、驗證者、密鑰、算法、待簽名消息簽名系統(tǒng)的參數(shù)包括:

——消息空間M,所有可能的消息的集合

——簽名空間S,所有可能的簽名的集合

——密鑰空間K,所有可能的密鑰的集合

——簽名者的密鑰,包括公鑰pK和私鑰sK兩部分

——算法:保密的簽名算法S(.)和公開的驗證算法V(..)第一節(jié)數(shù)字簽名概述數(shù)字簽名的原理(1)A→B:EKRa(M)提供鑒別與簽名只有A具有KRa傳輸中沒有被篡改任何第三方可以用KUa驗證簽名(1’)A→B:EKUb[EKRa(M)]

提供保密、鑒別與簽名第一節(jié)數(shù)字簽名概述直接數(shù)字簽名(DSS)(2)A→B:M||EKRa[H(M)]

提供鑒別及數(shù)字簽名H(M)受到密碼算法的保護只有A能夠生成EKRa[H(M)](2’)A→B:EKUb[M||EKRa(H(M))]

提供保密性、鑒別和簽名第一節(jié)數(shù)字簽名概述直接數(shù)字簽名(DSS)驗證模式依賴于發(fā)送方的保密密鑰發(fā)送方要抵賴發(fā)送某一消息時,可能會聲稱其私有密鑰丟失或被竊,從而他人偽造了他的簽名對策:要求被簽名的信息包含一個時間戳(日期與時間),并要求將已暴露的密鑰報告給一個授權(quán)中心X的某些私有密鑰確實在時間T被竊取,敵方可以偽造X的簽名及早于或等于時間T的時間戳第一節(jié)數(shù)字簽名概述直接數(shù)字簽名的缺點引入仲裁者所有從發(fā)送方X到接收方Y(jié)的簽名消息首先送到仲裁者A,A將消息及其簽名進行一系列測試,以檢查其來源和內(nèi)容,然后將消息加上日期并與已被仲裁者驗證通過的指示一起發(fā)給Y。第一節(jié)數(shù)字簽名概述仲裁數(shù)字簽名(ADS)當X否認時,通過以下方法解決糾紛:

Y:向A發(fā)送EKay[IDx||M||EKax[IDx||H(M)]]

A:用Kay恢復(fù)IDx,M,和簽名(EKax[IDx||H(M)]),然后用Kax解密簽名并驗證散列碼第一節(jié)數(shù)字簽名概述仲裁數(shù)字簽名(ADS)Y不能直接驗證X的簽名,Y認為消息正確,只因為它來自A。因此,雙方都需要高度相信A:X必須信任A沒有暴露Kax,并且沒有生成錯誤的簽名

Y必須信任A僅當散列值正確并且簽名確實是X產(chǎn)生的情況下才發(fā)送消息(2)雙方都必須信任A能公正地處理爭議第一節(jié)數(shù)字簽名概述仲裁數(shù)字簽名(ADS)(b)單密鑰加密方式,消息對仲裁者不可見

(1)XA:IDx||EKxy[M]||EKax[IDx||H(EKxy[M])] (2)AY:EKay[IDx||EKxy[M]||EKax[IDx||H(EKxy[M])]||T]X與Y之間共享密鑰Kxy

第一節(jié)數(shù)字簽名概述仲裁數(shù)字簽名(ADS)(c)公鑰加密方式,消息對仲裁者不可見

(1)XA:IDx||EKRx[IDx||EKUy(EKRx[M])] (2)AY:EKRa[IDx||EKUy[EKRx[M]]||T]X:對消息M雙重加密:首先用X的私有密鑰KRx,然后用Y的公開密鑰KUy。雙重加密的消息對A以及對除Y以外的其它人都是保密的。A:檢查X的公開/私有密鑰對是否仍然有效,是則確認消息。第一節(jié)數(shù)字簽名概述仲裁數(shù)字簽名(ADS)(c)與(a)(b)相比具有以下好處:

1、在通信之前各方之間無須共享任何信息,從而避免了聯(lián)手作弊;

2、即使KRx暴露,只要KRa未暴露,就不會有時間戳不正確的消息被發(fā)送;

3、從X發(fā)送給Y的消息的內(nèi)容對A和任何其他人是保密的。第一節(jié)數(shù)字簽名概述仲裁數(shù)字簽名(ADS)掌握數(shù)字簽名的基本概念理解數(shù)字簽名的特征理解數(shù)字簽名的原理及分類方法小結(jié)數(shù)字簽名算法第二節(jié)RSA簽名算法ElGamal簽名算法DSA概述DSA簽名過程主要內(nèi)容Alice的公開密鑰:nA,eA;秘密密鑰:dA;消息m簽名算法:驗證算法:Alice要對秘密信息簽名時,先用私鑰計算簽名,再用公鑰加密。第二節(jié)常見簽名算法RSA簽名簽名:對信息m簽名時,首先選取隨機數(shù)k(1≤k≤p-2),k與p-1互素,計算

r=gk

modps=k-1(m-xr)modp-1或m=xr+ksmodp-1驗證:驗證者A驗證等式是否成立:gm=yrrs

modp

若正確,則(r,s)為m的合法簽名,否則為非法簽名。第二節(jié)常見簽名算法ElGamal簽名1991年美國國家標準局NIST將數(shù)字簽名算法DSA作為其數(shù)字簽名標準(DigitalSignatureStandard,DSS),DSA是ElGamal數(shù)字簽名算法的變形。使用了安全散列函數(shù)SHA-1,以長度小于264bits的明文作為輸入,產(chǎn)生160bit的消息摘要作為DSA的輸入。驗證簽名時必須使用相同的散列函數(shù)。數(shù)字簽名算法DSA簽名:對明文m

(1,q),簽名者選取隨機整數(shù)k,1≤k≤p-2且k與p-1互素,計算r=(gk

modp)modqs=k-1(H(m)+xr)modq其中kk-1modq≡1(r,s)即為消息m的數(shù)字簽名。數(shù)字簽名算法DSA驗證:計算w=s-1modq

u1=H(m)wmodqu2=rwmodqv=[(gu1yu2)modp]modq檢驗v=r是否成立。數(shù)字簽名算法DSA簽名者對消息m=1234簽名:選擇隨機數(shù)k=50,得k-1(mod101)=99計算簽名:r=(17050(mod7879)(mod101)=2518(mod101)=94s=(1234+75*94)99(mod101)=97簽名為(1234,94,97)Example數(shù)字簽名算法DSA掌握RSA簽名算法掌握ElGamal簽名算法理解隨機數(shù)在簽名中的作用理解DSA簽名過程小結(jié)橢圓曲線簽名第三節(jié)ECDSA算法ECDSA中的閾下信道ECDSA算法的變形主要內(nèi)容ECDSA(EllipticCurveDigitalSignatureAlgorithm)——DSA算法在橢圓曲線上的模擬。1992年,作為NIST所征集的DSS候選算法之一,ScottVanstone提出了ECDSA算法。后來被各標準化組織廣泛接受,1998年被ISO作為ISO14888-3標準,1999年被ANSI作為ANSIX9.62標準,2000年被IEEE作為IEEE1363-2000標準,同年被FIPS作為FIPS186-2標準。ECDSA簡介1.方案建立設(shè)U為簽名方,V為驗證方:(1)U建立橢圓曲線域參數(shù)T=(p,a,b,G,n,h);(2)U建立自己的密鑰對(dU,QU),QU

=dUG;(3)U選擇一個Hash函數(shù);(4)U

通過可靠的方式將所選擇的Hash函數(shù)和建立的橢圓曲線域參數(shù)T傳遞給V。算法描述2.簽名算法(1)選擇臨時密鑰對(k,R),其中R=kG=(xR,yR)與域參數(shù)T相關(guān)(2)令r=xR

(modn),如果r=0,返回1(3)計算待簽消息的hash值H=Hash(M),將H轉(zhuǎn)換成整數(shù)e(4)計算s

k-1(e+rdU)(modn),如果s=0,返回1(5)輸出S=(r,s)為數(shù)字簽名算法描述3.驗證算法(1)如果r,s

[1,n-1],驗證失敗(2)計算待簽消息的hash值H=Hash(M),將H轉(zhuǎn)換成整數(shù)e(3)計算u1

es-1(modn),u2

rs-1(modn)(4)計算R=(xR,yR)=u1G+u2QU,如果R=O,驗證失敗(5)令v=

xR

(modn),如果v=r,驗證成功,否則驗證失敗算法描述對ECDLP的攻擊ECDSA算法的安全性基于ECDLP問題的困難性。如果一種攻擊能夠從簽名者U的公鑰恢復(fù)出私鑰,攻擊者就可以偽造出U對任何消息的數(shù)字簽名。目前,當基點的階為大素數(shù)時,素數(shù)域上的ECDLP是不可解的。對密鑰生成的攻擊在密鑰生成過程中用到了秘密隨機或偽隨機數(shù),不安全的隨機或偽隨機數(shù)生成器將直接導(dǎo)致密碼被攻破。攻擊思路對哈希函數(shù)的攻擊簽名和驗證階段使用的哈希函數(shù)必須具備單向和抗沖突的特性。如果哈希函數(shù)不能抵抗沖突,攻擊者可能會發(fā)現(xiàn)消息(M1;M2)的碰撞,在U對消息M1簽名后可以偽造出對消息M2的簽名?;跓o效域參數(shù)和無效公鑰的攻擊ECDSA的安全性依賴于U使用的有效域參數(shù),無效的域參數(shù)對Pohlig-Hellman攻擊不免疫。U應(yīng)該確保所采用的域參數(shù)是有效的。V在驗證之前也應(yīng)該檢驗這些參數(shù)的有效性。攻擊思路閾下信道——在密碼協(xié)議中,存在一些特殊的編碼方法或數(shù)學(xué)結(jié)構(gòu),可以用于傳輸秘密消息。閾下信道主要存在于數(shù)字簽名和認證協(xié)議中。簽名者(發(fā)送方)可以將秘密信息隱藏在數(shù)字簽名之中,驗證者(接收方)通過事先約定的某種協(xié)議或參數(shù)恢復(fù)出閾下信息,這種秘密通信方式很難被第三方檢測到。與一般的加密傳輸相比,閾下信道具有更高的安全性。ECDSA中的閾下信道如果簽名中的附加數(shù)據(jù)量為αbit,其中βbit用來保證簽名的安全性,則理論上最大可以傳遞α-β

bit的閾下信息。利用了全部或幾乎全部α-βbit的附加數(shù)據(jù)的閾下信道為寬帶閾下信道,只利用了一小部分的為窄帶閾下信道?;謴?fù)閾下信息時需要簽名者密鑰的方式定義為方式I,不需要的定義為方式Ⅱ。在方式I中,簽名者的密鑰同時也是該閾下信道的恢復(fù)密鑰。ECDSA中的閾下信道在ECDSA中,由于s

k-1

(e+rdU)(modn),可得k

s-1

(e+rdU)(modn),(r,s)和e為簽名對于驗證者V來說,只要事先知道簽名者U的私鑰dU就可以恢復(fù)出k來。于是以k作為閾下信息,可以實現(xiàn)方式I的閾下信道。ECDSA中的閾下信道在數(shù)字簽名協(xié)議中補充以下步驟,就能設(shè)計出閾下通信協(xié)議:信道建立U為發(fā)送方,V為接收方:(1)U執(zhí)行方案建立協(xié)議。建立參數(shù)T,(dU,QU),Hash。(2)U將私鑰dU,秘密傳輸給V。ECDSA中的閾下信道閾下信息隱藏(1)U對秘密消息編碼,得到一整數(shù)k。(2)U建立臨時密鑰對(k,R),其中R=kG=(xR,yR)和域參數(shù)T相關(guān)。(3)U執(zhí)行以上簽名算法。ECDSA中的閾下信道閾下信息恢復(fù)(1)V執(zhí)行驗證協(xié)議。(2)V計算

k

s-1(e+rdU)(modn),恢復(fù)閾下信息。(3)V對k解碼恢復(fù)原始的秘密信息。ECDSA中的閾下信道ECDSA算法中的簽名附加數(shù)據(jù)量為(logn+logp)bit,而閾下信息k為lognbit,該信道是一種寬帶信道。按照目前對橢圓曲線參數(shù)的安全要求,通過這個信道可傳輸192bit以上的閾下信息。ECDSA中的閾下信道簽名算法(1)選擇臨時密鑰對(k,R),其中R=kG=(xR,yR)和域參數(shù)T相關(guān)。(2)令r=xR(modn),如果r=0,返回1。 (3)計算待簽名消息的hash值H=Hash(M),將H轉(zhuǎn)換成整數(shù)e。(4)計算s

dU-1(rk-e)(modn),如果s=0,返回1。(5)輸出S=(r,s)為數(shù)字簽名。ECDSA算法的變形一驗證算法(1)如果r,s

[1,n-1],驗證失敗。(2)計算待簽消息的hash值H=Hash(M),將H轉(zhuǎn)換成整數(shù)e(3)計算u1

er-1(modn),u2

sr-1(modn)(4)計算R=(xR,yR)=u1G+u2QU,如果R=O,驗證失敗。(5)令v=

xR(modn),如果v=r,驗證成功,否則驗證失敗。這個改進方案中,可以預(yù)計算dU-1,將計算結(jié)果存儲下來作為簽名參數(shù),在每次簽名時模乘dU-1即可,于是模逆轉(zhuǎn)化為模乘,運算量將減小。ECDSA算法的變形一簽名算法(1)選擇臨時密鑰對(k,R),其中R=kG=(xR,yR)和域參數(shù)T相關(guān);(2)令r=xR(modn),如果r=0,返回1;(3)計算待簽名消息的hash值H=Hash(M),將H轉(zhuǎn)換成整數(shù)e;(4)計算s

k(e+rdU)-1(modn),如果s=0,返回1;(5)S=(r,s)作為數(shù)字簽名。ECDSA算法的變形二驗證算法(1)如果r,s

[1,n-1],驗證失??;(2)計算待簽名消息的hash值H=Hash(M),將H轉(zhuǎn)換成整數(shù)e;(3)計算u1

es(modn),u2

rs(modn);(4)計算R=(xR,yR)=u1G+u2QU,如果R=O,驗證失敗。(5)令v=

xR(modn),如果v=r,驗證成功,否則驗證失敗。ECDSA算法的變形二掌握ECDSA簽名過程理解閾下信道的含義理解如何在ECDSA中利用閾下信道進行信息隱藏了解ECDSA的兩種變形小結(jié)第四節(jié)盲簽名三、盲簽名的原理及典型算法(重點)二、盲簽名的產(chǎn)生背景----電子投票主要內(nèi)容:一、盲簽名的基本概念盲簽名

盲簽名:是一類特殊的數(shù)字簽名,消息持有者希望簽名者對他的消息作數(shù)字簽名,但又不想讓簽名看到消息的真實內(nèi)容。一、盲簽名的基本概念1、遠程匿名投票20世紀80年代,密碼學(xué)家DavidChaum就建立過一個遠程匿名投票模型設(shè)立一個選舉委員會,其職責(zé)為:

規(guī)定選票格式。

確認選民身份。

統(tǒng)計選票。二、電子投票問題(盲簽名產(chǎn)生的背景)條件:所有投票人散居各城市,無法集中,利用普通郵政系統(tǒng)投票。選民選委會資格審查票數(shù)統(tǒng)計

①②⑤③④

1、遠程匿名投票

二、電子投票問題(盲簽名產(chǎn)生的背景)用電子手段解決以下三個關(guān)鍵問題:(1)如何使選委會看不到選票內(nèi)容?(2)選舉委員會如何蓋章?(3)選民如何確認收回的選票沒有被做上記號?2、電子投票二、電子投票問題(盲簽名產(chǎn)生的背景)1、盲簽名的特性(1)簽名人看不到所簽的“文件內(nèi)容”。(2)簽名人無法建立文件與他的簽名之間的聯(lián)系。三、盲簽名的原理及算法消息持有者簽名者MS=S(M)M=B(M)S=B-1(S

)

2、盲簽名的原理盲化盲簽名解盲

消息持有者希望簽名者對他的消息作數(shù)字簽名,但又不想讓簽名者看到消息的真實內(nèi)容。三、盲簽名的原理及算法1.不可偽造性除了簽名者本人外,任何人都不能以他的名義生成有效的盲簽名。2.不可抵賴性簽名者簽署了某個消息后將無法否認自己對消息的簽名。3.盲性簽名者不可能得到消息的具體內(nèi)容。4.不可跟蹤性一旦消息的簽名公開后,簽名者不能確定自己何時簽署的這條消息。一個好的盲簽名算法應(yīng)該具有以下的性質(zhì):

三、盲簽名的原理及算法3、基于RSA密碼的盲簽名算法(1)參數(shù)選取(同RSA公鑰密碼):選定p,q為大素數(shù),計算n=pq。選取秘密密鑰d,要求gcd(d,φ(n))=1。計算e,滿足de=1modφ(n)。

e,n

公開,其它參數(shù)均保密。三、盲簽名的原理及算法RSA數(shù)字簽名過程AliceBobn,epublicdprivates≡md

modngcd(m,n)=1m≡se

modnsSetp1:選定M,隨機數(shù)R。計算M

=ReM

modn簽名者消息持有者Setp2:計算S

=M

d

modnStep3:S=R-1S

modn

=M

dmodnStep4:驗證

Semodn?=M(2)簽名算法三、盲簽名的原理及算法(3)分析MM

(M,S)(M

,S

)

簽名人對簽的“文件內(nèi)容”是看不見的。即使公布文件內(nèi)容,簽名人也不能把文件與他所作的簽名聯(lián)系起來。

三、盲簽名的原理及算法(4)與普通RSA簽名比較MS=M

dmodnRSA簽名RSA盲簽名M?=S

emodnS

=M

dmodnM?=S

emodnMM

S=R-1S

modn三、盲簽名的原理及算法1.密鑰的長度;2.盲簽名的長度;3.盲簽名的算法和驗證算法。盲簽名的可操作性和實現(xiàn)速度取決于:三、盲簽名的原理及算法4、盲簽名技術(shù)的應(yīng)用現(xiàn)狀(1)匿名電子投票系統(tǒng)(2)電子商務(wù)系統(tǒng)中的匿名支付

Microsoft公司的eWallet系統(tǒng)。三、盲簽名的原理及算法主要內(nèi)容:(1)盲簽名的基本概念(2)盲簽名的產(chǎn)生背景。(3)基于RSA密碼的盲簽名算法。

四、小結(jié)及相關(guān)問題第五節(jié)代理簽名代理簽名的含義及特點代理簽名的分類M-U-O代理簽名方案主要內(nèi)容代理簽名:簽名者可以授權(quán)他人代理自己,由被指定的代理簽名者代表原始簽名者生成有效的簽名。1996年,Mambo、Usuda和Okamoto首先提出了代理簽名的概念。代理簽名系統(tǒng)中的參與者:原始簽名者獲得授權(quán)執(zhí)行簽名的一個或多個代理簽名者驗證者第五節(jié)代理簽名代理簽名應(yīng)滿足三個基本條件驗證者能夠像驗證原始簽名者的簽名那樣來驗證代理簽名;能夠容易區(qū)分代理簽名和原始簽名;原始簽名者對代理簽名者所作的代理簽名不可否認。代理簽名的特點第五節(jié)代理簽名Mambo、Usuda和Okamoto把代理簽名分為三類:完全代理簽名、部分代理簽名和具有證書的代理簽名。完全代理簽名(fulldelegation):原始簽名者通過可靠途徑直接把自己的簽名密鑰分發(fā)給代理簽名者,代理簽名者產(chǎn)生的簽名與原始簽名者所產(chǎn)生的簽名完全相同。代理簽名的分類第五節(jié)代理簽名部分代理簽名(partialdelegation),原始簽名者用自己的簽名密鑰生成代理簽名密鑰s,然后將代理簽名密鑰通過可靠途徑分發(fā)給代理簽名者。要求:代理簽名者不能由自己所獲得的代理簽名密鑰推算出原始簽名者的簽名密鑰。又可分為兩種:代理非保護代理簽名和代理保護代理簽名。代理簽名的分類第五節(jié)代理簽名具有證書的代理簽名(delegationbywarrant),分兩種類型:授權(quán)代理簽名和持票代理簽名。授權(quán)代理簽名(delegateproxy):原始簽名者用他的簽名密鑰使用普通的簽名方案簽一個文件(證書),然后把產(chǎn)生的證書發(fā)給代理簽名者。持票代理簽名(bearerproxy):證書由消息部分和原始簽名者對新產(chǎn)生的公鑰的簽名組成。原始簽名者把新產(chǎn)生的公鑰所對應(yīng)的私鑰以安全的方式發(fā)給代理簽名者。代理簽名的分類第五節(jié)代理簽名代理簽名又可分為強代理簽名和弱代理簽名。強代理簽名——代理簽名不僅能夠代表原始簽名者的簽名,也能代表代理簽名者的簽名;弱代理簽名——代理簽名只代表原始簽名者的簽名。代理簽名的分類第五節(jié)代理簽名2學(xué)時消息認證與Hash函數(shù)——公鑰密碼的應(yīng)用第七章消息認證概述認證函數(shù)消息認證碼Hash函數(shù)和MAC的安全性Hash算法主要內(nèi)容機密性(Confidentiality):確保信息不暴露給未經(jīng)授權(quán)的人或應(yīng)用進程。完整性(Integrity):只有得到允許的人或應(yīng)用進程才能修改數(shù)據(jù),并且能夠判別出數(shù)據(jù)是否已被更改。可用性(Availability):只有得到授權(quán)的用戶在需要時才可以訪問數(shù)據(jù),即使在網(wǎng)絡(luò)被攻擊時也不能阻礙授權(quán)用戶對網(wǎng)絡(luò)的使用。三種基本安全需求認證系統(tǒng)由認證編碼器和認證譯碼器組成條件:指定的接收者能檢驗和證實消息的合法性、真實性和完整性發(fā)送者和接收者不能抵賴除了合法的發(fā)送者,其它人不能偽造消息認證系統(tǒng)第一節(jié)消息認證認證函數(shù)的特點:必須是單向函數(shù)對于一個特定消息,很難找到另外一個消息與其具有相同的認證碼很難找到一對具有相同認證碼的消息認證函數(shù)第一節(jié)消息認證認證函數(shù)可分為三類:消息加密:將整個消息的密文作為認證符;消息認證碼(MAC):是消息和密鑰的公開函數(shù),產(chǎn)生定長的認證符;Hash函數(shù):將任意長的消息映射為定長的hash值的公開函數(shù),該hash值則作為認證符。認證函數(shù)第一節(jié)消息認證消息認證碼(MessageAuthenticationCode):利用密鑰生成固定長度的短數(shù)據(jù)塊(MAC),將其附加在消息之后,也稱為密碼校驗和(cryptographicchecksum)。MAC函數(shù)與加密的區(qū)別:不要求可逆性多對一不能用于數(shù)字簽名第一節(jié)消息認證用消息認證碼實現(xiàn)認證通過MAC,可以認證以下內(nèi)容:

a.接收者可以確信所收到的消息M未被篡改;

b.接收者可以確信消息來自真實的發(fā)送者;

c.如果消息中包含順序碼(如X.25,TCP),接收者可以確認消息的正常順序。消息認證碼第一節(jié)消息認證已知M和Ck(M)時,構(gòu)造滿足Ck(M’)=Ck(M)的消息M’在計算上不可行;Ck(M)應(yīng)是均勻分布的,即對任何隨機選擇的消息M和M’,Ck(M’)=Ck(M)的概率是2-n,其中n是MAC的位數(shù);設(shè)M’是M的某個已知的變換,即M’=f(M),例如可令f

表示對M的一位或多位取反,那么

Pr[Ck(M’)=Ck(M)]=2-n

對MAC的要求第一節(jié)消息認證十進制移位加MAC算法

1980年,Sievi提出,稱為十進制移位加算法(DecimalShiftandAddAlgorithm)簡記為DSA,適用于金融支付中的數(shù)值消息交換業(yè)務(wù),消息按十位十進制數(shù)字分段處理,不足十位時在右邊以0補齊基于DES的MAC算法

兩種:CBC模式和CFB模式。CBC模式是使用最廣泛的一種,被美國作為數(shù)據(jù)認證算法(DataAuthenticationAlgorithm),已被FIPS(FIPSPUB113)和ANSI(X9.17)作為標準。MAC算法第一節(jié)消息認證消息按64bit分組M1,M2,…,MN,不足時以0補齊,DES加密,設(shè)密鑰為K,初始向量為0,計算如下:

O1=EK(M1)

O2=EK(M2XORO1)

O3=EK(M3XORO2) …

ON=EK(MNXORON-1)取加密結(jié)果最左邊的r位作為認證碼。r的大小由通信雙方約定。第二節(jié)消息認證碼MAC算法——CBC模式散列函數(shù)(HashFunction):也稱哈希函數(shù),對任意長度的明文進行變換,得到相對應(yīng)的函數(shù)值,稱為散列值,或稱散列值、消息摘要(MessageDigest)、指紋(Fingerprint),變換的過程稱為散列變換。散列值的長度一般是固定的。用途:(1)消息鑒別碼;(2)數(shù)字簽名之前的預(yù)處理第二節(jié)散列函數(shù)第二節(jié)散列函數(shù)要求:對任意長度輸入進行變換,得到固定長度輸出求逆不可行對給定x,很難找到x’≠x,使得h(x’)=h(x)很難找到一對不同的x,x’,使得h(x’)=h(x)第二節(jié)散列函數(shù)對hash函數(shù)的要求滿足條件(1)(2)的稱之為單向散列函數(shù)(One-WayHashFunction)滿足條件(1)~(3)的稱之為弱散列函數(shù)(WeakHashFunction)或弱無碰撞的散列函數(shù)滿足條件(1)~(4)的稱之為強散列函數(shù)(StrongHashFunction)或強無碰撞的散列函數(shù)。對hash函數(shù)的要求第二節(jié)散列函數(shù)1978年,Rabin的方法利用DES的密碼分組鏈接模式設(shè)計將明文M按M=m1m2…mn進行分組,mi為64bit,按DES的CBC模式依次對每個分組進行加密,令h0=初始向量,hi=Emi[hi-1],加密過程不使用任何密鑰,G=hn為最終得到的散列值。第二節(jié)Hash函數(shù)Hash函數(shù)舉例散列函數(shù)用于簽名時,假設(shè)簽名消息為(x,y),y=sigk(h(x)),則攻擊者可用如下方式偽造攻擊者計算Z=h(x),找到x’≠x,但h(x’)=h(x),則(x’,y)構(gòu)成有效的簽名;攻擊者找到任意兩個不同消息x’,x,滿足h(x’)=h(x),令簽名者對h(x)簽名,則(x’,h(x))也是有效簽名;攻擊者偽造一個簽名Z,若能計算h-1(Z)=x,則(x,h(x))為有效簽名。對Hash函數(shù)的攻擊第二節(jié)散列函數(shù)對hash函數(shù)的攻擊可以看作是尋找碰撞的過程,攻擊者的主要目標不是恢復(fù)原始的明文,而是用非法消息替代合法消息進行偽造和欺騙,。攻擊方法:生日攻擊、中間相遇攻擊、窮舉攻擊第二節(jié)Hash函數(shù)對Hash函數(shù)的攻擊攻擊者通過一對已知的明文和散列值,就可以任意偽造其它明文的散列值,步驟如下:第一步,對已知明文M產(chǎn)生散列值G;第二步,將非法明文Q按Q=Q1Q2…Qn-2進行分組,每個分組長度為64bit;第三步,計算hi=EQi[hi-1],1≤i≤n-2;第二節(jié)Hash函數(shù)中間相遇攻擊第四步,產(chǎn)生232個不同的x,對每個x計算Ex[hn-2],再任意產(chǎn)生232個不同的y,對每個y計算Dy[G],D是對應(yīng)于E的解密函數(shù);第五步,找到一對對應(yīng)的x和y,使得Ex[hn-2]=Dy[G];第六步,生成新的明文Q′=Q1Q2…Qn-2xy。第二節(jié)Hash函數(shù)中間相遇攻擊Merkle在1989年提出了散列函數(shù)的通用結(jié)構(gòu):

a.將原始消息M分成固定長度的分組(Block)Mi;

b.對最后一個分組MN填充,并附上原始消息M的長度,

使其長度等于固定長度;

c.設(shè)定鏈接變量(chainingvalue)的初始值CV0;

d.定義壓縮函數(shù)f,CVi=f(CVi-1,Mi-1);

e.循環(huán)操作N次,最后一個CVN為散列值。第二節(jié)Hash函數(shù)Hash函數(shù)的通用結(jié)構(gòu)對hash函數(shù)的密碼分析主要集中在f的內(nèi)部結(jié)構(gòu)進行分析,并試圖找到能與f的執(zhí)行產(chǎn)生碰撞的有效方法。第二節(jié)Hash函數(shù)密碼分析2004年8月17日,美國加州圣巴巴拉,Crypto’2004。來自山東大學(xué)的王小云教授做了破譯MD5、HAVAL-128、MD4和RIPEMD算法的報告。第二節(jié)Hash函數(shù)密碼分析CollisionsforHashFunctionsMD4,MD5,HAVAL-128andRIPEMDMD5SHA-1RIPEMD-160HMAC第三節(jié)Hash算法Merkle于1989年提出hashfunction模型RonRivest于1990年提出MD41992年,RonRivest完成MD5(RFC1321)現(xiàn)行美國標準SHA-1以MD5的前身MD4為基礎(chǔ)第三節(jié)Hash算法MD5輸出:128bit分組長度:512bit算法細節(jié):填充→輪函數(shù)MD5總體特征第三節(jié)Hash算法Step1:Padding,

M→M’ |M’|448mod512 |M’|>|M|→

如果|M|448mod512,則|M’

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論