cari
Rumahpembangunan bahagian belakangTutorial PythonGunakan Python untuk melaksanakan penyulitan dan penyahsulitan RSA
Gunakan Python untuk melaksanakan penyulitan dan penyahsulitan RSAApr 14, 2023 pm 02:13 PM
pythonrsaPenyulitan dan penyahsulitan

Saya melihat artikel Bahasa Inggeris semalam [1] yang menunjukkan cara menggunakan Python untuk melaksanakan algoritma RSA Logik kod adalah sama seperti artikel sebelumnya Memahami Algoritma RSA boleh membaca artikel Memahami Algoritma RSA , yang menerangkan apa itu RSA, prinsip matematik RSA, dan memberikan contoh mudah Ia boleh dikatakan sebagai artikel paling mudah untuk memahami RSA dalam Quanzhihu (ini datang dari komen pembaca).

Saya menjalankan kod yang disediakan dalam bahasa Inggeris dan mendapati ia tidak boleh menyulitkan bahasa Cina, jadi saya mengubah suai fungsi penyulitan dan penyahsulitan untuk menyokong penyulitan dan penyahsulitan bahasa Cina. Artikel hari ini akan berkongsi cara menggunakan Python untuk melaksanakan penyulitan dan proses penyahsulitan RSA untuk membantu anda mewujudkan pemahaman intuitif tentang RSA Algoritma penjanaan nombor perdana rawak dalam kod juga patut dipelajari.

0. Demonstrasi kesan

Mari kita lihat kesannya dahulu.

Teks asal: "Ada tahi lalat, tamatkan transaksi"

Gunakan Python untuk melaksanakan penyulitan dan penyahsulitan RSA

Cryptotext, yang tidak boleh dipecahkan sama sekali:

Gunakan Python untuk melaksanakan penyulitan dan penyahsulitan RSA

Selepas penyahsulitan:

Gunakan Python untuk melaksanakan penyulitan dan penyahsulitan RSA

Akaun awam kod lengkap "Python No. 7" boleh diperolehi dengan membalas "rsa".

1. Penjanaan pasangan kunci

Idea:

1) Cari secara rawak dua nombor perdana (nombor perdana) p dan q Lebih besar p dan q, lebih selamat Di sini kita memilih nombor perdana 1024-bit:

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

Proses pelaksanaan fungsi genprime() tidak akan dibincangkan terlebih dahulu.

2) Kira hasil mereka n = p * q dan fungsi Euler lambda_n.

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

3) Pilih integer e secara rawak, dengan syarat 1

e = 35537

4) Cari integer d supaya baki e * d dibahagikan dengan lambda_n ialah 1, dan kembalikan pasangan kunci.

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

Perlaksanaan fungsi eucalg akan dibincangkan kemudian.

Pada ketika ini, fungsi penjanaan pasangan kunci adalah seperti berikut:

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 Pelaksanaan penyulitan dan penyahsulitan

Proses penyulitan dan penyahsulitan adalah sama. , penyulitan kunci awam , Penyahsulitan kunci persendirian, dan sebaliknya, penyulitan kunci persendirian dan penyahsulitan kunci awam, tetapi yang pertama dipanggil penyulitan dan yang terakhir dipanggil tandatangan.

Pelaksanaan fungsi khusus adalah seperti berikut:

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

Fungsi modpow digunakan di sini, yang digunakan untuk mengira formula b^e % n = r.

  • Jika ia adalah proses penyulitan, maka b ialah teks biasa, (n, e) ialah kunci awam, dan r ialah teks sifir.
  • Jika ia adalah proses penyahsulitan, maka b ialah teks sifir, (n, d) ialah kunci persendirian, dan r ialah teks yang terkenal.

modpow ditakrifkan seperti berikut:

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. Fungsi penjanaan nombor perdana rawak

Fungsi penjanaan nombor perdana rawak, yang menggunakan pendaraban matriks dan Fibo Urutan itu menunjukkan kepentingan matematik kepada algoritma.

# 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. Pelaksanaan fungsi eucalg

Intipati fungsi adalah untuk mencari penyelesaian kepada persamaan linear berikut bagi dua pembolehubah:

e * x - lambda_n * y =1

Spesifik kod:

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. Ujian

kaedah penggunaan skrip test.py:

1), jana kunci

python test.py make-keys rsakey

Kunci awam disimpan dalam rsakey.pub , kunci peribadi disimpan dalam rsakey.priv

2), menyulitkan kandungan fail

Jika terdapat plaintext fail .txt:

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

akan menjana ciphertext .txt

3 Nyahsulit kandungan fail

Jika terdapat ciphertext.txt:

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

. .txt yang dinyahsulit akan menjadi. dihasilkan

Perkataan akhir

Artikel ini berkongsi pelaksanaan mudah algoritma RSA dalam Python, yang boleh membantu memahami algoritma RSA.


Atas ialah kandungan terperinci Gunakan Python untuk melaksanakan penyulitan dan penyahsulitan RSA. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan
Artikel ini dikembalikan pada:51CTO.COM. Jika ada pelanggaran, sila hubungi admin@php.cn Padam
详细讲解Python之Seaborn(数据可视化)详细讲解Python之Seaborn(数据可视化)Apr 21, 2022 pm 06:08 PM

本篇文章给大家带来了关于Python的相关知识,其中主要介绍了关于Seaborn的相关问题,包括了数据可视化处理的散点图、折线图、条形图等等内容,下面一起来看一下,希望对大家有帮助。

详细了解Python进程池与进程锁详细了解Python进程池与进程锁May 10, 2022 pm 06:11 PM

本篇文章给大家带来了关于Python的相关知识,其中主要介绍了关于进程池与进程锁的相关问题,包括进程池的创建模块,进程池函数等等内容,下面一起来看一下,希望对大家有帮助。

Python自动化实践之筛选简历Python自动化实践之筛选简历Jun 07, 2022 pm 06:59 PM

本篇文章给大家带来了关于Python的相关知识,其中主要介绍了关于简历筛选的相关问题,包括了定义 ReadDoc 类用以读取 word 文件以及定义 search_word 函数用以筛选的相关内容,下面一起来看一下,希望对大家有帮助。

归纳总结Python标准库归纳总结Python标准库May 03, 2022 am 09:00 AM

本篇文章给大家带来了关于Python的相关知识,其中主要介绍了关于标准库总结的相关问题,下面一起来看一下,希望对大家有帮助。

Python数据类型详解之字符串、数字Python数据类型详解之字符串、数字Apr 27, 2022 pm 07:27 PM

本篇文章给大家带来了关于Python的相关知识,其中主要介绍了关于数据类型之字符串、数字的相关问题,下面一起来看一下,希望对大家有帮助。

分享10款高效的VSCode插件,总有一款能够惊艳到你!!分享10款高效的VSCode插件,总有一款能够惊艳到你!!Mar 09, 2021 am 10:15 AM

VS Code的确是一款非常热门、有强大用户基础的一款开发工具。本文给大家介绍一下10款高效、好用的插件,能够让原本单薄的VS Code如虎添翼,开发效率顿时提升到一个新的阶段。

详细介绍python的numpy模块详细介绍python的numpy模块May 19, 2022 am 11:43 AM

本篇文章给大家带来了关于Python的相关知识,其中主要介绍了关于numpy模块的相关问题,Numpy是Numerical Python extensions的缩写,字面意思是Python数值计算扩展,下面一起来看一下,希望对大家有帮助。

python中文是什么意思python中文是什么意思Jun 24, 2019 pm 02:22 PM

pythn的中文意思是巨蟒、蟒蛇。1989年圣诞节期间,Guido van Rossum在家闲的没事干,为了跟朋友庆祝圣诞节,决定发明一种全新的脚本语言。他很喜欢一个肥皂剧叫Monty Python,所以便把这门语言叫做python。

See all articles

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

AI Hentai Generator

AI Hentai Generator

Menjana ai hentai secara percuma.

Artikel Panas

R.E.P.O. Kristal tenaga dijelaskan dan apa yang mereka lakukan (kristal kuning)
3 minggu yang laluBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Tetapan grafik terbaik
3 minggu yang laluBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Cara Memperbaiki Audio Jika anda tidak dapat mendengar sesiapa
3 minggu yang laluBy尊渡假赌尊渡假赌尊渡假赌

Alat panas

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

MantisBT

MantisBT

Mantis ialah alat pengesan kecacatan berasaskan web yang mudah digunakan yang direka untuk membantu dalam pengesanan kecacatan produk. Ia memerlukan PHP, MySQL dan pelayan web. Lihat perkhidmatan demo dan pengehosan kami.

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

Pelayar Peperiksaan Selamat

Pelayar Peperiksaan Selamat

Pelayar Peperiksaan Selamat ialah persekitaran pelayar selamat untuk mengambil peperiksaan dalam talian dengan selamat. Perisian ini menukar mana-mana komputer menjadi stesen kerja yang selamat. Ia mengawal akses kepada mana-mana utiliti dan menghalang pelajar daripada menggunakan sumber yang tidak dibenarkan.

PhpStorm versi Mac

PhpStorm versi Mac

Alat pembangunan bersepadu PHP profesional terkini (2018.2.1).