您好我正在使用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.