Go開發(fā)大全 20篇原創(chuàng)內(nèi)容 公眾號 【導(dǎo)讀】什么是對稱加密,?Go 語言做對稱加密怎么做?本文作者從加密原理到代碼實現(xiàn)帶你上車,。 對稱加密中,,加密和解密使用相同的密鑰,因此必須向解密者配送密鑰,,即密鑰配送問題,。而非對稱加密中,由于加密和解密分別使用公鑰和私鑰,,而公鑰是公開的,,因此可以規(guī)避密鑰配送問題。非對稱加密算法,,也稱公鑰加密算法,。 1977 年,Ron Rivest,、Adi Shamir,、Leonard Adleman 三人在美國公布了一種公鑰加密算法,即 RSA 公鑰加密算法,。RSA 是目前最有影響力和最常用的公鑰加密算法,,可以說是公鑰加密算法的事實標(biāo)準(zhǔn)。 一,、RSA 加密原理使用 M 和 C 分別表示明文和密文,,則 RSA 加密、解密過程如下: 其中 e,、n 的組合 (e, n) 即為公鑰,,d、n 的組合 (d, n) 即為私鑰,。當(dāng)然 e,、d、n 并非任意取值,,需要符合一定條件,,如下即為 e、d、n 的求解過程,。 生成密鑰對e,、d、n 的求解過程,,也即生成密鑰對的過程,。涉及如下步驟: 1、取兩個大質(zhì)數(shù)(也稱素數(shù))p,、q,,n = pq?! ?,、取正整數(shù) e、d,,使得 ed mod (p-1)(q-1) = 1,也即:ed ≡ 1 mod (p-1)(q-1),?! 和 d 是模 (p-1)(q-1) 的乘法逆元,僅當(dāng) e 與 (p-1)(q-1) 互質(zhì)時,,存在 d,。 舉例驗證: 1,、取 p,、q 分別為 13、17,,n = pq = 221,。 2,、而 (p-1)(q-1) = 12x16 = 192,,取 e、d 分別為 13,、133,,有 13x133 mod 192 = 1 取明文 M = 60,公鑰加密,、私鑰解密,,加密和解密過程分別如下: RSA 加密原理證明過程手動求解密鑰對中的 ded mod (p-1)(q-1) = 1,已知 e 和 (p-1)(q-1) 求 d,,即求 e 對模 (p-1)(q-1) 的乘法逆元,。 如上面例子中,p,、q 為 13,、17,(p-1)(q-1)=192,,取 e=13,,求 13d mod 192 = 1 中的 d?! ?3d ≡ 1 (mod 192),,在右側(cè)添加 192 的倍數(shù),使計算結(jié)果可以被 13 整除,?! ?3d ≡ 1 + 192x9 ≡ 13x133 (mod 192),因此 d = 133 其他計算方法有:費馬小定律,、擴展歐幾里得算法,、歐拉定理。 RSA 安全性由于公鑰公開,,即 e,、n 公開?! ∫虼似平?RSA 私鑰,,即為已知 e、n 情況下求 d,?! ∫?ed mod (p-1)(q-1) = 1,且 n=pq,,因此該問題演變?yōu)椋簩?n 質(zhì)因數(shù)分解求 p,、q?! ∧壳耙驯蛔C明,,已知 e、n 求 d 和對 n 質(zhì)因數(shù)分解求 p,、q 兩者是等價的,。實際中 n 長度為 2048 位以上,而當(dāng) n>200 位時分解 n 是非常困難的,,因此 RSA 算法目前仍被認為是安全實用的,。 RSA 計時***和防范RSA 解密的本質(zhì)是模冪運算,即: 其中 C 為密文,,(d,n) 為私鑰,,均為超過 1024 位的大數(shù)運算,,直接計算并不可行,因此最經(jīng)典的算法為蒙哥馬利算法,。而這種計算是比較是耗時的,,因此者可以觀察不同的輸入對應(yīng)的解密時間,通過分析推斷私鑰,,稱為計時,。而防范 RSA 計時的辦法,即在解密時加入隨機因素,,使得***者無法準(zhǔn)確獲取解密時間,。 具體實現(xiàn)步驟如下: 二,、Go RSA 加密解密1,、rsa 加解密,必然會去查 crypto/ras 這個包
這是該包的說明:實現(xiàn) RSA 加密技術(shù),,基于 PKCS#1 規(guī)范,。 對于什么是 PKCS#1,可以查閱相關(guān)資料,。PKCS(公鑰密碼標(biāo)準(zhǔn)),,而#1 就是 RSA 的標(biāo)準(zhǔn)??梢圆榭矗篜KCS 系列簡介 從該包中函數(shù)的名稱,可以看到有兩對加解密的函數(shù),。
這稱作加密方案,,詳細可以查看,PKCS #1 v2.1 RSA 算法標(biāo)準(zhǔn) 可見,,當(dāng)與其他語言交互時,,需要確定好使用哪種方案。 PublicKey 和 PrivateKey 兩個類型分別代表公鑰和私鑰,,關(guān)于這兩個類型中成員該怎么設(shè)置,,這涉及到 RSA 加密算法,本文中,,這兩個類型的實例通過解析文章開頭生成的密鑰得到,。 2、解析密鑰得到 PublicKey 和 PrivateKey 的實例這個過程,,我也是花了好些時間(主要對各種加密的各種東東不熟):怎么將 openssl 生成的密鑰文件解析到公鑰和私鑰實例呢,? 在 encoding/pem 包中,看到了—–BEGIN Type—–這樣的字樣,,這正好和 openssl 生成的密鑰形式差不多,,那就試試,。 在該包中,一個 block 代表的是 PEM 編碼的結(jié)構(gòu),,關(guān)于 PEM,,請查閱相關(guān)資料。我們要解析密鑰,,當(dāng)然用 Decode 方法:
這樣便得到了一個 Block 的實例(指針),。 解析來看 crypto/x509。為什么是 x509 呢,?這又涉及到一堆概念,。先不管這些,我也是看 encoding 和 crypto 這兩個包的子包摸索出來的,。在 x509 包中,,有一個函數(shù):
從該函數(shù)的說明:ParsePKIXPublicKey parses a DER encoded public key. These values are typically found in PEM blocks with “BEGIN PUBLIC KEY”??梢娺@就是解析 PublicKey 的,。另外,這里說到了 PEM,,可以上面的 encoding/pem 對了,。(PKIX 是啥東東,查看這里 ) 而解析私鑰的,,有好幾個方法,,從上面的介紹,我們知道,,RSA 是 PKCS#1,,剛好有一個方法:
返回的就是 rsa.PrivateKey。 代碼實現(xiàn):package main
- EOF - |
|
來自: 西北望msm66g9f > 《培訓(xùn)》