繁体   English   中英

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

[英]Python Why do I have Special Characters in RSA encrypting

您好我正在使用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?\xd2\xca7j\xa0\x0cw\x8b+R"\xc37\xe8IR\xa1\x9fu\xe7v\x0c\xcaW-\xfcXb;]\x887\xc9\xfd\xf6\x0f\xe7\xae\x08\xfe\x0b\xaa*\xfa\x1b\x95:c\x99\xcb\xc6\x9f\x1d\xe1\x84\xa6\xcb\x8adh\x97w\xacR\xff\x8c\x80\xedX\xcc\xf3\xc3\x99\x99\xe9\x92\x8e\xbf]>5\xc5\xbe\x0e*G\xe2\xf2m\xdeN\xa4\x19\xbf\xd6\xd6\x9c\xba\xf9\xc8f\xa7_\xef\x84q\x877\x90\xd3\xd5\x93\xef\x81\xfc $\x9e\x03\t\x9c\xb4\xb1D,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(整数到八位字节字符串原语)的函数中的模数大小相同的大小(即:字节中的密钥大小)。 确切地说,它是无符号大端表示。

加密是基于字节的,并且许多字节值在特定字符编码中没有对应的字符(或字形)。 有些语言会显示十六进制,如\\x0c ,有些会显示其他字形,如 ,没有关于如何显示不可表示的二进制代码的标准。

例如,问题\\x0c是数字12的十六进制。 \\x部分表示以下两个字符将被解释为十六进制

如果需要字符表示,那么通常使用的编码是Base64和十六进制。

花一些时间来检查字符编码,从ASCII开始,然后是utf-8,这种理解将随着时间的推移为您提供良好的服务。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM