加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 编程开发 > Python > 正文

Python为什么我在RSA加密中有特殊字符

发布时间:2020-12-20 12:04:47 所属栏目:Python 来源:网络整理
导读:您好我正在使用Pyzmq在 python中编写应用程序,用于PC客户端和覆盆子服务器之间的通信.我需要PC客户端将加密密码发送到raspberry服务器.我将发布我的代码的RSA部分,所以如果您需要更多信息或我的程序的其他部分,请告诉我. 所以在我的覆盆子上,我这样做生成一
您好我正在使用Pyzmq在 python中编写应用程序,用于PC客户端和覆盆子服务器之间的通信.我需要PC客户端将加密密码发送到raspberry服务器.我将发布我的代码的RSA部分,所以如果您需要更多信息或我的程序的其他部分,请告诉我.

所以在我的覆盆子上,我这样做生成一个RSA密钥:

from Crypto.Hash import MD5
from Crypto.PublicKey import RSA
from Crypto.Util import randpool

alea = randpool.RandomPool()
RSAKey = RSA.generate(1024,alea.get_bytes)

然后我得到这个RSAKey的n和e参数,它们在公钥对应,将它们发送到我的PC客户端.

当我的PC从Raspberry收到这些信息时,我在客户端上构建了公钥:

from Crypto.Hash import MD5
from Crypto.PublicKey import RSA

def create_public_key(n,e):
    key_params = (long(n),long(e))
    return RSA.construct(key_params)

然后,当用户输入他的密码时,我想加密它:

def encrypt(text):
    crypted = Client_Public_Key.encrypt(text,32)
    return crypted[0]

这是我得到的文字“12345”的加密:

('C?xd2xca7jxa0x0cwx8b+R"xc37xe8IRxa1x9fuxe7vx0cxcaW-xfcXb;]x887xc9xfdxf6x0fxe7xaex08xfex0bxaa*xfax1bx95:cx99xcbxc6x9fx1dxe1x84xa6xcbx8adhx97wxacRxffx8cx80xedXxccxf3xc3x99x99xe9x92x8exbf]>5xc5xbex0e*Gxe2xf2mxdeNxa4x19xbfxd6xd6x9cxbaxf9xc8fxa7_xefx84qx877x90xd3xd5x93xefx81xfc $x9ex03tx9cxb4xb1D,Q',)

我尝试了不同的加密方式(比如Cipher的PKCS1_OAEP),我总是得到这些奇怪的字符串.为什么我没有得到正常的数字序列?

我想继续使用这个库的解密函数,因为它非常快,但加密功能一直让我烦恼.

我能做什么 ?谢谢 !

在我的电脑上,我使用Spyder和Python 2.7.14.
在我的Raspberry上,我使用Python 3.5.x.

解决方法

现代密码对字节而不是字符进行操作,既用于输入,也用于输出.有时字符会被隐式编码为字节 – 通常是ASCII或ASCII兼容,例如Windows-1252(扩展拉丁语).

但是,密文(几乎)与随机无法区分,这意味着如果您将结果视为字符,那么您将获得“垃圾”,因为输出将包含不可打印的字符.你很幸运,因为你得到了这些字节值的十六进制表示,而不是带有中文字符的Unicode.

要获取文本,您应该转换为base 64或十六进制(更“可读”,效率更低).

RSA – 计算 – 本身在加密期间产生一个数字:使用公共指数进行模幂运算的结果.但是,RSA标准(PKCS#1)将此数字转换为固定长度字节数组,该数组具有与I2OSP(整数到八位字节字符串原语)的函数中的模数大小相同的大小(即:字节中的密钥大小).确切地说,它是无符号大端表示.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读