Как реализовать функциональность OpenSSL в Python? - PullRequest
13 голосов
/ 06 октября 2011

Я хотел бы зашифровать секретный текст открытым ключом и расшифровать его закрытым ключом в Python.Я могу добиться этого с помощью команды openssl:

echo "secrettext/2011/09/14 22:57:23" | openssl rsautl -encrypt -pubin -inkey public.pem | base64  data.cry
base64 -D data.cry | openssl rsautl -decrypt -inkey private.pem

Как реализовать это в Python?

Ответы [ 3 ]

20 голосов
/ 06 октября 2011

Шифрование

#!/usr/bin/env python
import fileinput
from M2Crypto import RSA

rsa = RSA.load_pub_key("public.pem")
ctxt = rsa.public_encrypt(fileinput.input().read(), RSA.pkcs1_oaep_padding)
print ctxt.encode('base64')

Расшифровать

#!/usr/bin/env python
import fileinput
from M2Crypto import RSA

priv = RSA.load_key("private.pem")
ctxt = fileinput.input().read().decode('base64')
print priv.private_decrypt(ctxt, RSA.pkcs1_oaep_padding)

Зависимость:

  • M2Crypto (похоже, только для Python 2)

См. Также Как зашифровать строку с помощью ключа и Как лучше всего кодировать строку с помощью открытого ключа в python .

3 голосов
/ 09 октября 2011

Вероятно, самый простой способ получить точно такое же поведение - использовать pyOpenSSL - это тонкая оболочка Python для самого OpenSSL.

1 голос
/ 06 октября 2011

Модули m2crypto предоставляют большую часть функциональных возможностей OpenSSL для Python, включая шифрование, дешифрование и подпись для общего / частного использования.

Большинство дистрибутивов Linux предоставляют модуль m2crypto как собственныйпакет.

...