Python 为什么我的RSA加密有特殊字符
Python Why do I have Special Characters in RSA encrypting
您好,我目前正在 python 中使用 Pyzmq 编写一个应用程序,用于 PC 客户端和树莓派服务器之间的通信。我需要 PC 客户端将加密密码发送到树莓派服务。我只会 post 我代码的 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 参数,它们对应于 Public 密钥,将它们发送到我的 PC 客户端。
当我的 PC 从 Raspberry 接收到这些信息时,我在客户端构建 Public 密钥:
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 一起使用。
在我的树莓派上,我使用 Python 3.5.x.
加密是基于字节的,许多字节值在特定字符编码中没有对应的字符(或字形)。有些语言会显示十六进制,例如 \x0c
,有些会显示其他字形,例如 �,没有关于如何显示无法表示的二进制代码的标准。
例如问题 \x0c
是数字 12 的十六进制。\x
部分表示以下两个字符将被解释为十六进制
如果需要字符表示,则通常使用的编码是 Base64 和十六进制。
花点时间研究一下字符编码,从 ASCII 开始,然后是 utf-8,随着时间的推移,这种理解会对你有所帮助。
现代密码对字节而不是字符进行运算,无论是输入还是输出。有时字符被隐式编码为字节 - 通常是 ASCII 或 ASCII 兼容,例如 Windows-1252(扩展拉丁语)。
但是,密文(几乎)与随机文本无法区分,这意味着如果您将结果视为字符,那么您将得到 "garbage",因为输出将包含不可打印的字符。你很幸运,因为你得到了这些字节值的十六进制表示,而不是带有中文字符的 Unicode。
要获取文本,您应该转换为 base 64 或十六进制(更多 "readable",效率较低)。
RSA - 计算 - 本身在加密过程中产生一个数字:使用 public 指数的模幂运算的结果。但是,RSA 标准 (PKCS#1) 在称为 I2OSP(整数到八位字节字符串原语)的函数中将此数字转换为具有相同模数大小(即:以字节为单位的密钥大小)的固定长度字节数组。准确地说是无符号大端表示。
您好,我目前正在 python 中使用 Pyzmq 编写一个应用程序,用于 PC 客户端和树莓派服务器之间的通信。我需要 PC 客户端将加密密码发送到树莓派服务。我只会 post 我代码的 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 参数,它们对应于 Public 密钥,将它们发送到我的 PC 客户端。
当我的 PC 从 Raspberry 接收到这些信息时,我在客户端构建 Public 密钥:
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 一起使用。 在我的树莓派上,我使用 Python 3.5.x.
加密是基于字节的,许多字节值在特定字符编码中没有对应的字符(或字形)。有些语言会显示十六进制,例如 \x0c
,有些会显示其他字形,例如 �,没有关于如何显示无法表示的二进制代码的标准。
例如问题 \x0c
是数字 12 的十六进制。\x
部分表示以下两个字符将被解释为十六进制
如果需要字符表示,则通常使用的编码是 Base64 和十六进制。
花点时间研究一下字符编码,从 ASCII 开始,然后是 utf-8,随着时间的推移,这种理解会对你有所帮助。
现代密码对字节而不是字符进行运算,无论是输入还是输出。有时字符被隐式编码为字节 - 通常是 ASCII 或 ASCII 兼容,例如 Windows-1252(扩展拉丁语)。
但是,密文(几乎)与随机文本无法区分,这意味着如果您将结果视为字符,那么您将得到 "garbage",因为输出将包含不可打印的字符。你很幸运,因为你得到了这些字节值的十六进制表示,而不是带有中文字符的 Unicode。
要获取文本,您应该转换为 base 64 或十六进制(更多 "readable",效率较低)。
RSA - 计算 - 本身在加密过程中产生一个数字:使用 public 指数的模幂运算的结果。但是,RSA 标准 (PKCS#1) 在称为 I2OSP(整数到八位字节字符串原语)的函数中将此数字转换为具有相同模数大小(即:以字节为单位的密钥大小)的固定长度字节数组。准确地说是无符号大端表示。