国产av日韩一区二区三区精品,成人性爱视频在线观看,国产,欧美,日韩,一区,www.成色av久久成人,2222eeee成人天堂

目錄
0、效果演示
1、密鑰對(duì)的生成
2、加解密的實(shí)現(xiàn)
3、隨機(jī)質(zhì)數(shù)的生成函數(shù)
4、eucalg 函數(shù)的實(shí)現(xiàn)
5、測(cè)試
1)、生成密鑰
2)、對(duì)文件內(nèi)容加密
3、 對(duì)文件內(nèi)容解密
首頁(yè) 后端開(kāi)發(fā) Python教程 用 Python 來(lái)實(shí)現(xiàn) RSA 加解密

用 Python 來(lái)實(shí)現(xiàn) RSA 加解密

Apr 14, 2023 pm 02:13 PM
python rsa 加解密

昨天看到一篇英文文章[1],展示了如何用 Python 來(lái)實(shí)現(xiàn) RSA 算法,代碼的邏輯與前文一文搞懂 RSA 算法一樣,不太熟悉 RSA 的朋友可以看一下一文搞懂 RSA 算法,里面對(duì)什么是 RSA,RSA 的數(shù)學(xué)原理進(jìn)行了說(shuō)明,并舉了一個(gè)簡(jiǎn)單的例子,可以說(shuō)是全知乎最容易讀懂 RSA 的文章了(這話來(lái)自讀者評(píng)論)。

這篇英文提供的代碼我運(yùn)行了下,發(fā)現(xiàn)不能加密中文,于是就修改了下加解密的函數(shù),讓其支持中文加解密。今天的文章就分享一下如何用 Python 來(lái)實(shí)現(xiàn) RSA 加解密的這一過(guò)程,幫助你建立 RSA 的直觀認(rèn)識(shí),代碼里的隨機(jī)素?cái)?shù)生成算法,也值得我們學(xué)習(xí)。

0、效果演示

咱們先看下效果。

原文:“有內(nèi)鬼,終止交易”

用 Python 來(lái)實(shí)現(xiàn) RSA 加解密

密文,根本無(wú)法破解:

用 Python 來(lái)實(shí)現(xiàn) RSA 加解密

解密之后:

用 Python 來(lái)實(shí)現(xiàn) RSA 加解密

完整代碼公眾號(hào)「Python七號(hào)」回復(fù)「rsa」獲取。

1、密鑰對(duì)的生成

思路:

1)隨機(jī)找兩個(gè)質(zhì)數(shù)(素?cái)?shù)) p 和 q,p 與 q 越大,越安全,這里選擇 1024 位的質(zhì)數(shù):

p = genprime(1024)
q = genprime(1024)

genprime() 函數(shù)的實(shí)現(xiàn)過(guò)程先不說(shuō)。

2)計(jì)算他們的乘積 n = p * q 及 歐拉函數(shù) lambda_n。

n = p * q
lambda_n = (p - 1) * (q - 1)

3)隨機(jī)選擇一個(gè)整數(shù) e,條件是 1 < e < lambda_n,且 e 與 lambda_n 互質(zhì)。比如選擇 35537,35537 只有 16 位,必然小于 lambda_n。

e = 35537

4)找到一個(gè)整數(shù) d,可以使得 e * d 除以 lambda_n 的余數(shù)為 1,并返回密鑰對(duì)。

d = eucalg(e, lambda_n)[0]
if d < 0: d += lambda_n
return (d, n), (e, n)

eucalg 函數(shù)的實(shí)現(xiàn)放后面說(shuō)。

至此,密鑰對(duì)的生成的函數(shù)如下:

def create_keys():
 p = genprime(1024)
 q = genprime(1024)
 n = p * q
 lambda_n = (p - 1) * (q - 1)
 e = 35537
 d = eucalg(e, lambda_n)[0]
 if d < 0: d += lambda_n
 return (d, n), (e, n)

2、加解密的實(shí)現(xiàn)

加密和解密的過(guò)程是一樣的,公鑰加密,私鑰解密,反過(guò)來(lái)也可以,私鑰加密,公鑰解密,只不過(guò)前者我們叫加密,后者我們叫簽名。

具體的函數(shù)實(shí)現(xiàn)如下:

def encrypt_data(data,key):
e_data = []
for d in data:
 e = modpow(d, key[0], key[1]) 
 e_data.append(e)
return e_data

## 加密和解密的邏輯完全一樣
decrypt_data = encrypt_data

這里面用到了 modpow 函數(shù),它用來(lái)計(jì)算公式 b^e % n = r 的。

  • 如果是加密過(guò)程,那么 b 是明文,(n,e)為公鑰,r 為密文。
  • 如果是解密過(guò)程,那么 b 是密文,(n,d)為私鑰,r 為名文。

modpow 的定義如下:

def modpow(b, e, n):
 # find length of e in bits
 tst = 1
 siz = 0
 while e >= tst:
tst <<= 1
siz += 1
 siz -= 1
 # calculate the result
 r = 1
 for i in range(siz, -1, -1):
r = (r * r) % n
if (e >> i) & 1: r = (r * b) % n
 return r

3、隨機(jī)質(zhì)數(shù)的生成函數(shù)

隨機(jī)質(zhì)數(shù)的生成函數(shù),其中用到了矩陣乘法和斐波那契數(shù)列,可見(jiàn)數(shù)學(xué)對(duì)于算法的重要性。

# matrix multiplication
def sqmatrixmul(m1, m2, w, mod):
 mr = [[0 for j in range(w)] for i in range(w)]
 for i in range(w):
for j in range(w):
 for k in range(w):
mr[i][j] = (mr[i][j] + m1[i][k] * m2[k][j]) % mod
 return mr

# fibonacci calculator
def fib(x, mod):
 if x < 3: return 1
 x -= 2
 # find length of e in bits
 tst = 1
 siz = 0
 while x >= tst:
tst <<= 1
siz += 1
 siz -= 1
 # calculate the matrix
 fm = [
# function matrix
[0, 1],
[1, 1]
 ]
 rm = [
# result matrix
# (identity)
[1, 0],
[0, 1]
 ]
 for i in range(siz, -1, -1):
rm = sqmatrixmul(rm, rm, 2, mod)
if (x >> i) & 1:
 rm = sqmatrixmul(rm, fm, 2, mod)

 # second row of resulting vector is result
 return (rm[1][0] + rm[1][1]) % mod

def genprime(siz):
 while True:
num = (1 << (siz - 1)) + secrets.randbits(siz - 1) - 10;
# num must be 3 or 7 (mod 10)
num -= num % 10
num += 3 # 3 (mod 10)
# heuristic test
if modpow(2, num - 1, num) == 1 and fib(num + 1, num) == 0:
 return num
num += 5 # 7 (mod 10)
# heuristic test
if modpow(2, num - 1, num) == 1 and fib(num + 1, num) == 0:
 return num

4、eucalg 函數(shù)的實(shí)現(xiàn)

函數(shù)的本質(zhì)在于求下面二元一次方程的解:

e * x - lambda_n * y =1

具體代碼:

def eucalg(a, b):
 # make a the bigger one and b the lesser one
 swapped = False
 if a < b:
a, b = b, a
swapped = True
 # ca and cb store current a and b in form of
 # coefficients with initial a and b
 # a' = ca[0] * a + ca[1] * b
 # b' = cb[0] * a + cb[1] * b
 ca = (1, 0)
 cb = (0, 1)
 while b != 0:
# k denotes how many times number b
# can be substracted from a
k = a // b
# swap a and b so b is always the lesser one
a, b, ca, cb = b, a-b*k, cb, (ca[0]-k*cb[0], ca[1]-k*cb[1])
 if swapped:
return (ca[1], ca[0])
 else:
return ca

5、測(cè)試

test.py 腳本使用方法:

1)、生成密鑰

python test.py make-keys rsakey

公鑰保存在 rsakey.pub 中, 私鑰保存在 rsakey.priv 中

2)、對(duì)文件內(nèi)容加密

假如有文件 明文.txt:

python test.py encrypt 明文.txt from rsakey to 密文.txt

將生成 密文.txt

3、 對(duì)文件內(nèi)容解密

假如有文件 密文.txt:

python test.py decrypt 密文.txt as rsakey to 解密后.txt

將生成 解密后.txt

最后的話

本文分享了 RSA 算法的 Python 的簡(jiǎn)單實(shí)現(xiàn),可以幫助理解 RSA 算法。


以上是用 Python 來(lái)實(shí)現(xiàn) RSA 加解密的詳細(xì)內(nèi)容。更多信息請(qǐng)關(guān)注PHP中文網(wǎng)其他相關(guān)文章!

本站聲明
本文內(nèi)容由網(wǎng)友自發(fā)貢獻(xiàn),版權(quán)歸原作者所有,本站不承擔(dān)相應(yīng)法律責(zé)任。如您發(fā)現(xiàn)有涉嫌抄襲侵權(quán)的內(nèi)容,請(qǐng)聯(lián)系admin@php.cn

熱AI工具

Undress AI Tool

Undress AI Tool

免費(fèi)脫衣服圖片

Undresser.AI Undress

Undresser.AI Undress

人工智能驅(qū)動(dòng)的應(yīng)用程序,用于創(chuàng)建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用于從照片中去除衣服的在線人工智能工具。

Clothoff.io

Clothoff.io

AI脫衣機(jī)

Video Face Swap

Video Face Swap

使用我們完全免費(fèi)的人工智能換臉工具輕松在任何視頻中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費(fèi)的代碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

功能強(qiáng)大的PHP集成開(kāi)發(fā)環(huán)境

Dreamweaver CS6

Dreamweaver CS6

視覺(jué)化網(wǎng)頁(yè)開(kāi)發(fā)工具

SublimeText3 Mac版

SublimeText3 Mac版

神級(jí)代碼編輯軟件(SublimeText3)

熱門(mén)話題

如何處理Python中的API身份驗(yàn)證 如何處理Python中的API身份驗(yàn)證 Jul 13, 2025 am 02:22 AM

處理API認(rèn)證的關(guān)鍵在于理解并正確使用認(rèn)證方式。1.APIKey是最簡(jiǎn)單的認(rèn)證方式,通常放在請(qǐng)求頭或URL參數(shù)中;2.BasicAuth使用用戶名和密碼進(jìn)行Base64編碼傳輸,適合內(nèi)部系統(tǒng);3.OAuth2需先通過(guò)client_id和client_secret獲取Token,再在請(qǐng)求頭中帶上BearerToken;4.為應(yīng)對(duì)Token過(guò)期,可封裝Token管理類自動(dòng)刷新Token;總之,根據(jù)文檔選擇合適方式,并安全存儲(chǔ)密鑰信息是關(guān)鍵。

如何用Python測(cè)試API 如何用Python測(cè)試API Jul 12, 2025 am 02:47 AM

要測(cè)試API需使用Python的Requests庫(kù),步驟為安裝庫(kù)、發(fā)送請(qǐng)求、驗(yàn)證響應(yīng)、設(shè)置超時(shí)與重試。首先通過(guò)pipinstallrequests安裝庫(kù);接著用requests.get()或requests.post()等方法發(fā)送GET或POST請(qǐng)求;然后檢查response.status_code和response.json()確保返回結(jié)果符合預(yù)期;最后可添加timeout參數(shù)設(shè)置超時(shí)時(shí)間,并結(jié)合retrying庫(kù)實(shí)現(xiàn)自動(dòng)重試以增強(qiáng)穩(wěn)定性。

Python函數(shù)可變范圍 Python函數(shù)可變范圍 Jul 12, 2025 am 02:49 AM

在Python中,函數(shù)內(nèi)部定義的變量是局部變量,僅在函數(shù)內(nèi)有效;外部定義的是全局變量,可在任何地方讀取。1.局部變量隨函數(shù)執(zhí)行結(jié)束被銷毀;2.函數(shù)可訪問(wèn)全局變量但不能直接修改,需用global關(guān)鍵字;3.嵌套函數(shù)中若要修改外層函數(shù)變量,需使用nonlocal關(guān)鍵字;4.同名變量在不同作用域互不影響;5.修改全局變量時(shí)必須聲明global,否則會(huì)引發(fā)UnboundLocalError錯(cuò)誤。理解這些規(guī)則有助于避免bug并寫(xiě)出更可靠的函數(shù)。

Python Fastapi教程 Python Fastapi教程 Jul 12, 2025 am 02:42 AM

要使用Python創(chuàng)建現(xiàn)代高效的API,推薦使用FastAPI;其基于標(biāo)準(zhǔn)Python類型提示,可自動(dòng)生成文檔,性能優(yōu)越。安裝FastAPI和ASGI服務(wù)器uvicorn后,即可編寫(xiě)接口代碼。通過(guò)定義路由、編寫(xiě)處理函數(shù)并返回?cái)?shù)據(jù),可以快速構(gòu)建API。FastAPI支持多種HTTP方法,并提供自動(dòng)生成的SwaggerUI和ReDoc文檔系統(tǒng)。URL參數(shù)可通過(guò)路徑定義捕獲,查詢參數(shù)則通過(guò)函數(shù)參數(shù)設(shè)置默認(rèn)值實(shí)現(xiàn)。合理使用Pydantic模型有助于提升開(kāi)發(fā)效率和準(zhǔn)確性。

與超時(shí)的python循環(huán) 與超時(shí)的python循環(huán) Jul 12, 2025 am 02:17 AM

為Python的for循環(huán)添加超時(shí)控制,1.可結(jié)合time模塊記錄起始時(shí)間,在每次迭代中判斷是否超時(shí)并使用break跳出循環(huán);2.對(duì)于輪詢類任務(wù),可用while循環(huán)配合時(shí)間判斷,并加入sleep避免CPU占滿;3.進(jìn)階方法可考慮threading或signal實(shí)現(xiàn)更精確控制,但復(fù)雜度較高,不建議初學(xué)者首選;總結(jié)關(guān)鍵點(diǎn):手動(dòng)加入時(shí)間判斷是基本方案,while更適合限時(shí)等待類任務(wù),sleep不可缺失,高級(jí)方法適用于特定場(chǎng)景。

如何在Python中解析大型JSON文件? 如何在Python中解析大型JSON文件? Jul 13, 2025 am 01:46 AM

如何在Python中高效處理大型JSON文件?1.使用ijson庫(kù)流式處理,通過(guò)逐項(xiàng)解析避免內(nèi)存溢出;2.若為JSONLines格式,可逐行讀取并用json.loads()處理;3.或先將大文件拆分為小塊再分別處理。這些方法有效解決內(nèi)存限制問(wèn)題,適用于不同場(chǎng)景。

python循環(huán)在元組上 python循環(huán)在元組上 Jul 13, 2025 am 02:55 AM

在Python中,用for循環(huán)遍歷元組的方法包括直接迭代元素、同時(shí)獲取索引和元素、以及處理嵌套元組。1.直接使用for循環(huán)可依次訪問(wèn)每個(gè)元素,無(wú)需管理索引;2.使用enumerate()可同時(shí)獲取索引和值,默認(rèn)索引起始為0,也可指定start參數(shù);3.對(duì)嵌套元組可在循環(huán)中解包,但需確保子元組結(jié)構(gòu)一致,否則會(huì)引發(fā)解包錯(cuò)誤;此外,元組不可變,循環(huán)中不能修改內(nèi)容,可用\_忽略不需要的值,且建議遍歷前檢查元組是否為空以避免錯(cuò)誤。

Python默認(rèn)論點(diǎn)及其潛在問(wèn)題是什么? Python默認(rèn)論點(diǎn)及其潛在問(wèn)題是什么? Jul 12, 2025 am 02:39 AM

Python默認(rèn)參數(shù)在函數(shù)定義時(shí)評(píng)估并固定值,可能導(dǎo)致意外問(wèn)題。使用可變對(duì)象如列表作為默認(rèn)參數(shù)會(huì)保留修改,建議用None代替;默認(rèn)參數(shù)作用域是定義時(shí)的環(huán)境變量,后續(xù)變量變化不影響其值;避免依賴默認(rèn)參數(shù)保存狀態(tài),應(yīng)使用類封裝狀態(tài)以確保函數(shù)一致性。

See all articles