密码学(一):RSA加密长文

简介:

RSA简介: RSA加密是一种非对称加密,至于它底层实现比较复杂,说实话我说不清楚可能把你带沟里去了,感兴趣的同学可以去看看这篇博文:点击这里,或者可以看看漫画更容易理解:点击这里今天我们要说的不是他的实现原理,你们用RSA进行一次性加密长文是不被允许的,我们今天重点的话题是用它加密长文!!!

RSA组成:

RSA是由公钥和私钥组成的一对密钥,密钥分成公钥和私钥,公钥是公开的而私钥自己持有的,私钥是用来加密的,加密后的内容叫做密文,公钥是给别人用来对你加密后的密文进行解密,解密后的内容叫做明文。

正文:

一、生成密钥代码:

from Cryptodome.PublicKey import RSA


# 生成密钥
rsa = RSA.generate(1024)
print(rsa.export_key())
print(rsa.publickey().export_key())
with open('pri.bin', mode='wb') as f:
    f.write(rsa.export_key())
with open('pub.pem', mode='wb') as f:
    f.write(rsa.publickey().export_key())

私钥:
在这里插入图片描述
公钥:
在这里插入图片描述
说明:
先说下代码,代码总的逻辑是生成密钥对并保存,记住RSA密钥是成对出现的,代码里面的RSA.generate(1024)是关键,而后面的1024是bit单位,可用去看看源码里面的说明。再说一下公钥和私钥,密钥的开头可用来区分公钥和私钥,看上面两图。

二、加密代码:

from Cryptodome.PublicKey import RSA
from Crypto.Cipher import PKCS1_v1_5
import base64


text = '一只快死的猿'
# 加载秘钥
pub_key = open('pub.pem').read()
# 实例化一个秘钥对象
key = RSA.import_key(pub_key)
# 生成加密对象
cipher = PKCS1_v1_5.new(key)
# 加密
encode_rsa_data = cipher.encrypt(text.encode())
# 解码
b64_data = base64.b64encode(encode_rsa_data)
print(b64_data.decode())

说明:
加密后的密文:ETWDk+DngrXX2OoK6cusKZ90oLX3l1NcTFwfkrafSvs5OBjMDygCVo+Weiemy+5ORxJ2j8PXb8JEU3fQjO8UuF1edpTA8ZJ/8z9RY90I7tl3Cixp77yG/ml8anNn8FJwoUsa6aS2KOqYxpGM+AjQLh3JUBZPh7NQOnQEgyCAXik=

密文是一堆乱码,看不懂也不重要,重要的是看末尾的”=“,首先你要知道你生成密钥的时候指定的1024bit在这个地方起作用了,这时密文的长度固定是172,如果密文是2048bit,那么这时密文的程度固定是344,你可以多试试就可用发现它的规律了,而回过头看”=“,如果加密后的密文长度不足172的话,那它会在末尾补上”=“直到172的长度,这也就是为什么密文是固定的。

再说说代码:注意的地方就是明文加密之前要先进行b64编码

扫描二维码关注公众号,回复: 14001534 查看本文章

三、解密代码:

from Cryptodome.PublicKey import RSA
from Crypto.Cipher import PKCS1_v1_5
import base64


text = 'thTmi5mFXjtj3LSXO825EUtKOa6Tr03kVmCcSmS/LfJNtYxQ9xXeRar0Glr2p1FVQjITd0CoT8cQbZhyQjg05JCbso7YPi6M79o0UI9bfbZwEGJeh+En7mez1gJuJmA1jDUor0v38dudbvFZSm5ibi/mWsPFc+1KPJIBZMkX8Tk='
# 加载秘钥
pri_key = open('pri.bin').read()
# 实例化一个秘钥对象
key = RSA.import_key(pri_key)
data = base64.b64decode(text.encode())
# 生成解密对象
rsa = PKCS1_v1_5.new(key)
decode_rsa_data = rsa.decrypt(data, b'rsa')
print(decode_rsa_data.decode())

说明:解密后的明文就是"一只快死的猿",代码注意的点就是要进行b64解码,这里要注意加密和解码要进行B64处理后才可以进行加解密操作。

重点扩展: 好了上面说完了RSA的基本操作,后进入我们今天的重点,用RSA进行加密长文!

前面已经提到了几个重点:
1、是生成密钥的时候要指定密钥的长度为1024、2048 …
2、RSA只能加密短文本,比如我们的request_id,token或者一些重要的识标符,因为比较短,但是这里要说明一下,具体它能加密最大的文本长度我没研究过。
3、对应生成的密文长度的规律,前面提到的172和344
接下来要说的是怎么利用RSA来加密长文本的逻辑:其实就是把长文本分段切割成小字符串,然后再进行加密,这个是个技术活,需要找到它加密的规律,要怎么切割才能符合规则?

下面是我之前写的一个小demo用来处理长文本的,废话不多说直接上源码,代码里面有具体说明:
点击这里下载代码
上面是我的github地址,代码已经上传,感兴趣可以去看看哈

结语: 欢乐的学习时光总是短暂的,今天的内容就到此结束吧。如果这篇博文有帮到你或者,你觉得对RSA加密有了进一步的了解,那也请你不要吝啬你的一键三连,还有github记得收藏好东西都在上面了,有时间再分享其他的加密哈~~~~

猜你喜欢

转载自blog.csdn.net/xiaoxin_OK/article/details/116209322