摘要:二如何理解公鑰和私鑰非對稱加密算法需要兩個密鑰公開密鑰和私有密鑰。因為加密和解密使用的是兩個不同的密鑰,所以這種算法叫作非對稱加密算法。三非對稱加密解密原理非對稱加密算法中,常用的就是算法了,以下就以算法為例來講解非對稱加密算法的實現(xiàn)原理。
非對稱加密,在現(xiàn)在網(wǎng)絡(luò)應(yīng)用中,有這非常廣泛的場景,更是加密貨幣的基礎(chǔ)。本文主要介紹非對稱加密、解密的原理和過程,以及在區(qū)塊鏈中的使用。
一、非對稱加密解密過程A要向B發(fā)送信息,A和B都要產(chǎn)生一對用于加密、解密的公鑰和私鑰
A保管自己的私鑰,把公鑰告訴B;B保管自己的私鑰,把公鑰告訴A
A要給B發(fā)送信息時,A用B的公鑰加密信息,因為A知道B的公鑰。
A將這個消息發(fā)給B(已經(jīng)用B的公鑰加密消息)。
B收到這個消息后,B用自己的私鑰解密A的消息。其他所有收到這個報文的人都無法解密,因為只有B才有B的私鑰。
二、如何理解公鑰和私鑰??非對稱加密算法需要兩個密鑰:公開密鑰(public key)和私有密鑰(private key)。公開密鑰與私有密鑰是一對,如果用公開密鑰對數(shù)據(jù)進行加密,只有用對應(yīng)的私有密鑰才能解密;如果用私有密鑰對數(shù)據(jù)進行加密,那么只有用對應(yīng)的公開密鑰才能解密。因為加密和解密使用的是兩個不同的密鑰,所以這種算法叫作非對稱加密算法。
??非對稱加密算法實現(xiàn)機密信息交換的基本過程是:甲方生成一對密鑰并將其中的一把作為公用密鑰向其它方公開;得到該公用密鑰的乙方使用該密鑰對機密信息進行加密后再發(fā)送給甲方;甲方再用自己保存的另一把專用密鑰對加密后的信息進行解密。
??非對稱密碼的特點:算法強度復雜、安全性依賴于算法與密鑰,但是由于其算法復雜,而使得加密解密速度沒有對稱加密解密的速度快。對稱密碼體制中只有一種密鑰,并且是非公開的,如果要解密就得讓對方知道密鑰。所以保證其安全性就是保證密鑰的安全,而非對稱密鑰體制有兩種密鑰,其中一個是公開的,這樣就可以不需要像對稱密碼那樣傳輸對方的密鑰了。這樣安全性就大了很多。
非對稱加密算法中,常用的就是RSA算法了,以下就以RSA算法為例來講解非對稱加密算法的實現(xiàn)原理。
RSA算法的基于這樣的數(shù)學事實:兩個大質(zhì)數(shù)相乘得到的大數(shù)難以被因式分解。
RSA加密過程
$$ 密文=明文^E mod N $$
解釋:也就是說RSA加密是對明文的E次方后除以N后求余數(shù)的過程。也就是說只要知道E(Encryption)和N(Number),任何人都可以進行RSA加密了。其中E、N是RSA加密的密鑰,E和N的組合就是公鑰,我們用(E,N)來表示公鑰
$$ 公鑰=(E,N) $$
不過E和N不并不是隨便什么數(shù)都可以的,它們都是經(jīng)過嚴格的數(shù)學計算得出的
RSA解密過程
$$ 明文=密文^D mod N $$
也就是說對密文進行D次方后除以N的余數(shù)就是明文,這就是RSA解密過程。知道D和N就能進行解密密文了,所以D和N的組合就是私鑰
$$ 私鑰=(D,N) $$
從上述可以看出RSA的加密方式和解密方式是相同的,加密是求"E次方的mod N",解密是求"D次方的mod N"
知道上述的幾個簡單公式后,剩下就是計算各個參數(shù)對應(yīng)的值了
求N。準備兩個質(zhì)數(shù)p,q,這兩個數(shù)不能太小,太小則會容易破解,將p乘以q就是N。
$$ N=p?q $$
求L。L為中間數(shù),是 (p-1) 和 (q-1) 的最小公倍數(shù),可用如下表達式表示
$$ L=lcm(p-1,q-1) $$
求E。E必須滿足兩個條件:E是一個比1大比L小的數(shù),E和L的最大公約數(shù)為1,用gcd(X,Y)來表示X,Y的最大公約數(shù)則E條件如下:
$$ 1 < E < L $$
$$ gcd(E,L)=1 $$
之所以需要E和L的最大公約數(shù)為1是為了保證一定存在解密時需要使用的數(shù)D。現(xiàn)在我們已經(jīng)求出了E和N也就是說我們已經(jīng)生成了密鑰對中的公鑰了。
求D。D是由數(shù)E計算出來的。D、E和L之間必須滿足以下關(guān)系:
$$ 1 < D < L $$
$$ E * D mod L = 1 $$
至此,公鑰和私鑰都都計算出來了,大家可以自己試著計算下
四、為何非對稱加密難以破解??破解RSA算法的關(guān)鍵就是計算N、p、q的值,給出兩個很大的質(zhì)數(shù)p、q,可以計算N,但知道N,去很難算出p、q,只能不停的嘗試,這就是為什么當前RSA很難破解。
??RSA算法的破解與密鑰的長度有關(guān),如果密鑰的長度小于等于256位,一臺較快的電腦可以在幾個小時內(nèi)成功分解其因子。位數(shù)越高因式分解所需時間也越長。例如破解RSA-2048(2048-bit)的密鑰需要耗費傳統(tǒng)電腦10億年的時間,而量子計算機只需要100秒就可以完成。所以隨著科技的發(fā)展,算法也會更新?lián)Q代。
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/24267.html
摘要:公鑰哈希和錢包地址可以通過互逆運算進行轉(zhuǎn)換,所以它們是等價的。使用私鑰對交易進行簽名比特幣錢包間的轉(zhuǎn)賬是通過交易實現(xiàn)的。使用公鑰對簽名進行驗證交易數(shù)據(jù)被廣播到比特幣網(wǎng)絡(luò)后,節(jié)點會對這個交易數(shù)據(jù)進行檢驗,其中就包括對簽名的校驗。 一句話解釋公鑰、私鑰、地址私鑰:實際上是一組隨機數(shù),關(guān)于區(qū)塊鏈中的隨機數(shù)我們已經(jīng)介紹過了公鑰:對私鑰進行橢圓曲線加密算法生成,但是無法通過公鑰倒推得到私鑰。公...
摘要:算法公鑰加密算法是年由羅納德李維斯特阿迪薩莫爾和倫納德阿德曼一起提出的。是目前最有影響力的公鑰加密算法,它能夠抵抗到目前為止已知的絕大多數(shù)密碼攻擊,已被推薦為公鑰數(shù)據(jù)加密標準。 上篇文章介紹了對稱加密的原理,但是它的最大問題就是加密和解密的密鑰是相同的,并且不能保證密鑰能安全的送到雙方手里,即使安全的送到雙方手里,免不了內(nèi)部會有臥底的存在 非對稱加密 既然有對稱加密,那么自然會聯(lián)想到非...
摘要:請勿在密碼學強度系統(tǒng)中使用編程語言提供的通用偽隨機數(shù)生成器實現(xiàn)。該偽隨機數(shù)發(fā)生器是密碼學意義上最強的偽隨機數(shù)發(fā)生器之一,應(yīng)用在金融安全和上。 一、隨機數(shù)分類 1、真隨機數(shù)其定義為隨機樣本不可重現(xiàn)。實際上只要給定邊界條件,真隨機數(shù)實際上并不存在,可是如果產(chǎn)生一個真隨機數(shù)樣本的邊界條件十分復雜且難以捕捉,可以認為用這個方法演算出來了真隨機數(shù)。例如骰子、轉(zhuǎn)輪、噪音等。 2、偽隨機數(shù),通過一定...
摘要:假如黎曼猜想被證實,區(qū)塊鏈將毀滅近日,黎曼猜想四個字瘋狂刷屏。黎曼猜想由數(shù)學家波恩哈德黎曼于年提出。因此,黎曼猜想一旦被證明,則意味著素數(shù)之密被解開,算法也就將被攻破了。而大多數(shù)區(qū)塊鏈所用的加密算法不是,而是橢圓曲線加密算法。 瑪麗女王的密碼之生死命懸一線 showImg(https://segmentfault.com/img/bVbhD7s?w=740&h=876); 16世紀伊麗...
摘要:本文首發(fā)于深入淺出區(qū)塊鏈社區(qū)原文鏈接非對稱加密技術(shù)算法數(shù)學原理分析原文已更新,請讀者前往原文閱讀非對稱加密技術(shù),在現(xiàn)在網(wǎng)絡(luò)中,有非常廣泛應(yīng)用。加密技術(shù)更是數(shù)字貨幣的基礎(chǔ)。 本文首發(fā)于深入淺出區(qū)塊鏈社區(qū)原文鏈接:非對稱加密技術(shù) - RSA算法數(shù)學原理分析原文已更新,請讀者前往原文閱讀非對稱加密技術(shù),在現(xiàn)在網(wǎng)絡(luò)中,有非常廣泛應(yīng)用。加密技術(shù)更是數(shù)字貨幣的基礎(chǔ)。 所謂非對稱,就是指該算法需要一...
閱讀 1393·2021-11-24 09:38
閱讀 2095·2021-09-22 15:17
閱讀 2393·2021-09-04 16:41
閱讀 3487·2019-08-30 15:56
閱讀 3520·2019-08-29 17:19
閱讀 1981·2019-08-28 18:09
閱讀 1258·2019-08-26 13:35
閱讀 1718·2019-08-23 17:52