數(shù)字簽名技術(shù)與應(yīng)用課件_第1頁
數(shù)字簽名技術(shù)與應(yīng)用課件_第2頁
數(shù)字簽名技術(shù)與應(yīng)用課件_第3頁
數(shù)字簽名技術(shù)與應(yīng)用課件_第4頁
數(shù)字簽名技術(shù)與應(yīng)用課件_第5頁
已閱讀5頁,還剩29頁未讀, 繼續(xù)免費閱讀

下載本文檔

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

文檔簡介

數(shù)字簽名的引入---網(wǎng)絡(luò)傳經(jīng)我要接受來自黃裳的九陰真經(jīng)安全的要求:我能確保經(jīng)文來自黃裳我能確保經(jīng)文在因特網(wǎng)上傳輸沒有別人能夠看到經(jīng)文,因為那是發(fā)送給我的,這樣就防止了經(jīng)文被竊黃裳事后不能否認發(fā)送了經(jīng)文給我數(shù)字簽名的引入---網(wǎng)絡(luò)傳經(jīng)我要接受來自黃裳的九陰真經(jīng)1發(fā)送過程把九陰真經(jīng)發(fā)給我發(fā)送過程把九陰真經(jīng)發(fā)給我2解決方法發(fā)信息的人用自己的私鑰對所發(fā)信息進行加密(Encryption)接收信息者用發(fā)信者的公鑰來解密(Decryption)可以保證信息的真實性、完整性和不可否認性。解決方法發(fā)信息的人用自己的私鑰對所發(fā)信息進行加密(Encr3問題還沒解決要發(fā)的信息可能很長,非對稱密碼又比較復(fù)雜,運算量大。私鑰通常保存在USBKey或IC卡中,加密運算也是在Key或卡中進行加密所用的時間就會很長而導(dǎo)致無法實用黑客用自己的私鑰加密葵花寶典用它替換掉黃裳給我的經(jīng)文并發(fā)給我我需要以某種方式來認證該經(jīng)文的確來自黃裳并且沒有被黑客修改或者替換問題還沒解決要發(fā)的信息可能很長,非對稱密碼又比較復(fù)雜,運算量4哈希函數(shù)·1.什么是哈希函數(shù)

哈希(Hash)函數(shù)在中文中有很多譯名,有些人根據(jù)Hash的英文原意譯為“散列函數(shù)”或“雜湊函數(shù)”,有些人干脆把它音譯為“哈希函數(shù)”,還有些人根據(jù)Hash函數(shù)的功能譯為“壓縮函數(shù)”、“消息摘要函數(shù)”、“指紋函數(shù)”、“單向散列函數(shù)”等等。

哈希函數(shù)·1.什么是哈希函數(shù)

哈希(Hash)函數(shù)在5Hash算法是把任意長度的輸入數(shù)據(jù)經(jīng)過算法壓縮,輸出一個尺寸小了很多的固定長度的數(shù)據(jù),即哈希值。哈希值也稱為輸入數(shù)據(jù)的數(shù)字指紋(DigitalFingerprint)或消息摘要(MessageDigest)等。

Hash函數(shù)具備以下的性質(zhì):

1給定輸入數(shù)據(jù),很容易計算出它的哈希值;

2反過來,給定哈希值,倒推出輸入數(shù)據(jù)則很難,計算上不可行。這就是哈希函數(shù)的單向性,在技術(shù)上稱為抗原像攻擊性;

Hash算法是把任意長度的輸入數(shù)據(jù)經(jīng)過算法壓縮,輸出一個尺寸6

4、給定哈希值,想要找出能夠產(chǎn)生同樣的哈希值的兩個不同的輸入數(shù)據(jù),(這種情況稱為碰撞,Collision),這很難,計算上不可行,在技術(shù)上稱為抗碰撞攻擊性;

5、哈希值不表達任何關(guān)于輸入數(shù)據(jù)的信息。

4、給定哈希值,想要找出能夠產(chǎn)生同樣的哈希值的兩個不同的輸7哈希函數(shù)用于消息驗證哈希函數(shù)用于消息驗證8密碼學(xué)中使用的哈希算法都被設(shè)計為具有某些特殊的性質(zhì):你無法反向執(zhí)行哈希算法來恢復(fù)出哪怕是一點兒最初的明文。得到的摘要不會告訴你任何關(guān)于最初明文的信息。創(chuàng)建/發(fā)現(xiàn)哈希值為某個特定值的明文,這在計算上是不可行的。這使得攻擊者無法在替換文件的同時確保哈希值仍然匹配。密碼學(xué)中使用的哈希算法都被設(shè)計為具有某些特殊的性質(zhì):9解答:哈希函數(shù)+數(shù)字簽名黃裳用哈希算法生成九陰真經(jīng)的摘要,用自己的私鑰加密摘要把加密的摘要和九陰真經(jīng)(明文)發(fā)給我用黃裳的公鑰解密摘要,恢復(fù)摘要對收到九陰真經(jīng)采用相同算法創(chuàng)建一個新摘要比較兩個摘要:如果摘要匹配,發(fā)送者是作者;明文在發(fā)送過程中沒有被改動。解答:哈希函數(shù)+數(shù)字簽名黃裳用哈希算法生成九陰真經(jīng)的摘要,用10數(shù)字簽名及驗證過程數(shù)字簽名及驗證過程11發(fā)信者在發(fā)信前使用哈希算法求出待發(fā)信息的數(shù)字摘要,然后用私鑰對這個數(shù)字摘要,而不是待發(fā)信息本身,進行加密而形成一段信息,這段信息稱為數(shù)字簽名。發(fā)信時將這個數(shù)字簽名信息附在待發(fā)信息后面,一起發(fā)送過去。收信者收到信息后,一方面用發(fā)信者的公鑰對數(shù)字簽名解密,得到一個摘要H;另一方面把收到的信息本身用哈希算法求出另一個摘要H’,再把H和H’相比較,看看兩者是否相同。發(fā)信者在發(fā)信前使用哈希算法求出待發(fā)信息的數(shù)字摘要,然后用私鑰12根據(jù)哈希函數(shù)的特性,我們可以讓簡短的摘要來“代表”信息本身,如果兩個摘要H和H’完全符合,證明信息是完整的;如果不符合,就說明信息被人篡改了。哈希函數(shù)的安全性直接關(guān)系到數(shù)字簽名的安全性,如果哈希函數(shù)被攻破,數(shù)字簽名的有效性就會受到質(zhì)疑。目前,已經(jīng)發(fā)明的Hash函數(shù)有多種,如Snefru、N-Hash、LOKI、AR、GOST、MD、SHA等。它們在數(shù)學(xué)上實現(xiàn)的方法各有不同,安全性也各有不同。目前比較常用的Hash函數(shù)是MD5和SHA-1。根據(jù)哈希函數(shù)的特性,我們可以讓簡短的摘要來“代表”信息本身,13

但是,任何一種算法都有其漏洞和局限性。任何一個哈希函數(shù)都會存在碰撞——即在一些特定情況下,兩個不同的文件或信息會指向同一個數(shù)字摘要。在一般情況下,類似碰撞只能盡可能地減少,而不能完全避免。從理論上講,沒有攻不破的密碼。隨著密碼科學(xué)的發(fā)展,也許會找到攻破某一種密碼算法的途徑。

但是,任何一種算法都有其漏洞和局限性。任何一個哈希函數(shù)都會14數(shù)字簽名的產(chǎn)生

政治、軍事、外交等領(lǐng)域的文件、命令和條約,商業(yè)中的契約,以及個人之間的書信等,傳統(tǒng)上都采用手書簽名或印章,以便在法律上能認證、核準和生效。隨著計算機通信網(wǎng)的發(fā)展,人們希望通過電子設(shè)備實現(xiàn)快速、遠距離的交易,數(shù)字(或電子)簽名法便應(yīng)運而生,并開始用于商業(yè)通信系統(tǒng),如電子郵遞、電子轉(zhuǎn)賬和辦公自動化等系統(tǒng)中。

數(shù)字簽名的產(chǎn)生政治、軍事、外交等領(lǐng)域的文件、命15數(shù)字簽名的要求類似于手書簽名,數(shù)字鑒名也應(yīng)滿足以下要求:(1)收方能夠確認或證實發(fā)方的簽名,但不能偽造。(2)發(fā)方發(fā)出簽名的消息送收方后,就不能再否認他所簽發(fā)的消息:(3)收方對已收到的簽名消息不能否認,即有收到認證。(4)第三者可以確認收發(fā)雙方之間的消息傳送,但不能偽造這一過程。數(shù)字簽名的要求類似于手書簽名,數(shù)字鑒名也應(yīng)滿足以下要求:16數(shù)字簽名與手書簽名的區(qū)別數(shù)字簽名與手書簽名的區(qū)別在于,手書簽名是模擬的,且因人而異。數(shù)字簽名是0和1的數(shù)字串,因消息而異。數(shù)字簽名與消息認證的區(qū)別在于,消息認證使收方能驗證消息發(fā)送者及所發(fā)消息內(nèi)容是否被纂改過。當收發(fā)者之間沒有利害沖突時,這對于防止第三者的破壞來說是足夠了。但當收者和發(fā)者之間有利害沖突時,單純用消息認證技術(shù)就無法解決他們之間的糾紛,此時須借助滿足前述要求的數(shù)字簽名技術(shù)數(shù)字簽名與手書簽名的區(qū)別數(shù)字簽名與手書簽名的區(qū)別在于,手書簽17數(shù)字簽名的分類數(shù)字簽名有兩種

(1)一種是對整個消息的簽名

(2)一種是對壓縮消息的簽名它們都是附加在被簽名消息之后或某一特定位置上的一段簽名圖樣。數(shù)字簽名的分類數(shù)字簽名有兩種18數(shù)字簽名的分類若按明、密文的對應(yīng)關(guān)系劃分,每一種又可分為兩個子類

(1)一類是確定性數(shù)字簽名。其明文與密文一一對應(yīng),它對一特定消息的簽名不變化(使用簽名者的密鑰簽名),如RSA、ElGamal等簽名。(2)另一類是隨機化的或概率式數(shù)字簽名。它對同一消息的簽名是隨機變化的,取決于簽名算法中的隨機參數(shù)和取值。數(shù)字簽名的分類若按明、密文的對應(yīng)關(guān)系劃分,每一種又可分為兩個19數(shù)字簽名的使用模式智慧卡像信用卡的磁卡,存儲有用戶的數(shù)字簽名信息密碼式用戶自己設(shè)定密碼,由特定的設(shè)備寫入計算機生物測定以使用者的身體特征為基礎(chǔ),用特殊的設(shè)備對使用者的指紋、面部、視網(wǎng)膜或眼球進行數(shù)字識別,從而確定對象是否與原使用者相同。數(shù)字簽名的使用模式智慧卡20簽名體制一個簽名體制一般含兩個組成部分.即簽名算法和驗證算法。對M的簽名可簡記有時為了說明密鑰k在簽名中的作用,也可以將簽名寫成對s的證實簡記為Ver(s0)={真,偽}={0,1}。簽名算法或簽名密鑰是秘密的,只有簽名人掌握。證實算法應(yīng)當公開,以便于他人進行驗證。簽名體制一個簽名體制一般含兩個組成部分.即簽名算法和驗證算法21數(shù)字簽名與加密的區(qū)別消息簽名與消息加密有所不同,消息加密和解密可能是一次性的,它要求在解密之前是安全的。而一個簽名的消息可能作為一個法律上的文件(如合同等),很可能在對消息簽署多年之后才驗證其簽名,且可能需要多次驗征此簽名。因此,簽名的安全性和防偽造的要求會更高,且要求證實速度比簽名速度要快些。特別是聯(lián)機在線時進行實時驗證。數(shù)字簽名與加密的區(qū)別消息簽名與消息加密有所不同,消息加密和解22使用數(shù)字簽名

隨著計算機網(wǎng)絡(luò)的發(fā)展,過去依賴于手書簽名的各種業(yè)務(wù)都可用這種電子化的數(shù)字簽名代替。它是實現(xiàn)電子貿(mào)易,電子支票、電子貨幣、電子出版及知識產(chǎn)權(quán)保護等系統(tǒng)安全的重要保證數(shù)字簽名已經(jīng)并將繼續(xù)對人們?nèi)绾喂蚕砗吞幚砭W(wǎng)絡(luò)上信息以及事務(wù)處理產(chǎn)生巨大的影響。為電子形式為文檔附上電子時間標簽。使用電子匯款系統(tǒng)的人可以利用電子鑒名數(shù)字簽名的使用已延伸到保護數(shù)據(jù)庫的應(yīng)用中使用數(shù)字簽名隨著計算機網(wǎng)絡(luò)的發(fā)展,過去依賴于手書簽名的各種234.2RSA簽名安全參數(shù):令n=qp,p和q是大素數(shù),選e并計算出d,使,公開n和e,將p、q和d保密。則所有的RSA參數(shù)為。數(shù)字簽名:對消息M屬于Z,定義對M的簽名:簽名驗證:對給定的M,S可按下式驗證:設(shè),如果M’=M,則簽名為真,否則,不接受簽名。4.2RSA簽名安全參數(shù):令n=qp,p和q是大素數(shù),選e并244.2RSA簽名RSA是是完整的加密系統(tǒng),它支持公鑰/私鑰對的生成、加密以及數(shù)字簽名。Carol為了機密消息以發(fā)送給Bob,Bob首先生成一個密鑰對,并和Carol共享公鑰。公鑰由兩個數(shù)字組成:模數(shù)n和公共指數(shù)e。私鑰也由兩個數(shù)字組成:相同的模數(shù)n和私有指數(shù)d。通過隨機選擇兩個大的質(zhì)數(shù)p和q,并把他們一起相乘,就可以創(chuàng)建模數(shù)。4.2RSA簽名RSA是是完整的加密系統(tǒng),它支持公鑰/私鑰對254.2RSA簽名所選擇的指數(shù)e必須與(p-1)和(q-1)互質(zhì)(也就是說,e與(p-1)和(q-1)這個數(shù)必須不具有相同的因數(shù)。質(zhì)數(shù)d必須滿足等式d*emod[(p-1)(q-1)]=1。然后,如果Carol的明文是M,那么,他就能夠通過計算C=Memodn把它加密成密文C。Bob通過計算M=Cdmodn就可以恢復(fù)明文。4.2RSA簽名所選擇的指數(shù)e必須與(p-1)和(q-1)互264.2RSA簽名第一步Bob選擇大的質(zhì)數(shù)p和q,并使他們相乘,從而得到n;第二步Bob選擇一個公共質(zhì)數(shù)e,它與(p-1)(q-1)是互質(zhì)數(shù);第三步Bob計算私有質(zhì)數(shù)d=e-1mod[(p-1)(q-1)];第四步Bob與Carol共享公鑰,數(shù)字n和e;第五步Bob使用C=Memodn把M加密成C,并把C發(fā)送給Bob;第六步Bob使用M=Cdmodn把C解密成M4.2RSA簽名第一步Bob選擇大的質(zhì)數(shù)p和q,并使他們相乘274.2RSA簽名這里有一個RSA加密的示例,同樣為了簡潔起見,在這個例子中使用的數(shù)字都很小。Bob選擇了質(zhì)數(shù)p=5和q=11,然后把這兩個數(shù)字相乘,從而得到模數(shù)n=55。Bob計算出f(n)=(p-1)*(q-1)=4*10=40Bob選擇一個數(shù)字e,e與40是互質(zhì)數(shù)。40的質(zhì)因數(shù)是2、2、2、5和1,所以Bob選擇的私有指數(shù)e=3。Bob選擇了一個公共指數(shù)d=3(-1)mod40。這個模數(shù)反函數(shù)實際上是非常困難的,但是對于所用的這些小數(shù)字,可以看到27*3mod40=81mod40=1。所以d=27。4.2RSA簽名這里有一個RSA加密的示例,同樣為了簡潔起見286.2RSA簽名現(xiàn)在Bob的公鑰就是數(shù)對(3,55),其私鑰就是數(shù)對(27,55)。Bob把自己的公鑰發(fā)送給Carol。Carol的消息M=25。它把該消息加密成密文C=25的3次冪mod55=15625mod55=5。Carol把結(jié)果發(fā)送給Bob。Bob使用M=5的27次冪mod55=7450580596923828125mod55=25對密文進行解密,這就是Carol的原始消息。6.2RSA簽名現(xiàn)在Bob的公鑰就是數(shù)對(3,55),其私鑰294.3ElGamal簽名

該體制由T.ElGamal在1985年給出。其修正形式已被美國NIST作為數(shù)字簽名標準(DSS),它是Rabin體制的一種變型。此體制專門為簽名用而設(shè)計,方案的安全性基于求離散對數(shù)的困難性??梢钥闯?,它是一種非確定性的雙鑰體制,即對同一明文消息,由于隨機參數(shù)選擇的不同而有不同的簽名。4.3ElGamal簽名該體制由T.ElGamal在198304.3ElGamal簽名1.體制參數(shù)

溫馨提示

  • 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. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論