Python使用Rsa公钥加密,私钥解密以及私钥签名,公钥验签的例子
来源:互联网 发布:软件招聘平台 编辑:程序博客网 时间:2024/05/22 14:47
安装Cryptor库
wget https://github.com/dlitz/pycrypto/archive/master.zip
python setup.py install
生成rsa公钥和私钥
私钥
openssl genrsa -out ./myPrivateKey.pem -passout pass:"f00bar" -des3 2048
用私钥生成公钥
openssl rsa -pubout -in ./myPrivateKey.pem -passin pass:"f00bar" -out ./myPublicKey.pem
Rsa公钥加密,私钥解密的Python代码
encrypto.py
#!/usr/bin/python
from Crypto.PublicKey import RSA
def encrypt(message):
externKey="./myPublicKey.pem"
privatekey = open(externKey, "r")
encryptor = RSA.importKey(privatekey, passphrase="f00bar")
encriptedData=encryptor.encrypt(message, 0)
file = open("./cryptThingy.txt", "wb")
file.write(encriptedData[0])
file.close()
if __name__ == "__main__":
encryptedThingy=encrypt("Loren ipsum")
decrypto.py
#!/usr/bin/python
from Crypto.PublicKey import RSA
def decrypt():
externKey="./myPrivateKey.pem"
publickey = open(externKey, "r")
decryptor = RSA.importKey(publickey, passphrase="f00bar")
retval=None
file = open("./cryptThingy.txt", "rb")
retval = decryptor.decrypt(file.read())
file.close()
return retval
if __name__ == "__main__":
decryptedThingy=decrypt()
print "Decrypted: %s" % decryptedThingy
Rsa私钥签名,公钥验签的Python代码
sign.py
from Crypto.PublicKey import RSA
from Crypto.Hash import SHA
from Crypto.Signature import PKCS1_v1_5
from base64 import b64encode
def rsa_sign(message):
private_key_file = open('./myPrivateKey.pem', 'r')
private_key = RSA.importKey(private_key_file)
hash_obj = SHA.new(message)
signer = PKCS1_v1_5.new(private_key)
d = b64encode(signer.sign(hash_obj))
file = open('./signThing.txt', 'wb')
file.write(d)
file.close()
if '__main__' == __name__:
rsa_sign('zhangshibo')
verify.py
from Crypto.PublicKey import RSA
from Crypto.Signature import PKCS1_v1_5
from Crypto.Hash import SHA
from base64 import b64decode
def rsa_verify(message):
public_key_file = open('./myPublicKey.pem', 'r')
public_key = RSA.importKey(public_key_file)
sign_file = open('./signThing.txt', 'r')
sign = b64decode(sign_file.read())
h = SHA.new(message)
verifier = PKCS1_v1_5.new(public_key)
return verifier.verify(h, sign)
if '__main__' == __name__:
print rsa_verify('zhangshibo')
0 0
- Python使用Rsa公钥加密,私钥解密以及私钥签名,公钥验签的例子
- Python 进行RSA私钥加密,公钥解密
- 公钥加密-私钥解密(RSA)
- C#使用RSA进行私钥加密公钥解密
- C#使用RSA进行私钥加密公钥解密
- java 实现RSA实现数据的私钥加密以及公钥解密
- python 利用pycrypto进行rsa生成公钥、私钥,加密、解密、签名、解签
- RSA公钥加密—私钥解密&私钥加密—公钥解密&私钥签名—公钥验证签名
- RSA加解密使用总结,.net私钥加密公钥解密,WinCE平台RSA加解密
- python rsa 私钥解密
- RSA不对称加密,公钥加密私钥解密,私钥加密公钥解密
- RSA不对称加密,公钥加密私钥解密,私钥加密公钥解密
- RSA不对称加密,公钥加密私钥解密,私钥加密公钥解密
- RSA不对称加密,公钥加密私钥解密,私钥加密公钥解密
- RSA不对称加密,公钥加密私钥解密,私钥加密公钥解密
- 银联手机支付(.Net Csharp),3DES加密解密,RSA加密解密,RSA私钥加密公钥解密,.Net RSA 3DES C#
- OpenSSL和Python实现RSA Key公钥加密私钥解密
- 苹果api rsa公钥加密私钥解密
- 观察者模式
- 玩儿转C语言:字符和字符串
- 学习 线性表的顺序存储 总结一
- 用栗子打倒C++多态
- AngularJs 父子级Controller传递数据
- Python使用Rsa公钥加密,私钥解密以及私钥签名,公钥验签的例子
- 24-ssh启动出现rt.jar:Permission denied
- 汇编记录(99) 汇编指令
- android点击空白区域隐藏软键盘
- uImage、zImage、bzImage、vlinzx区别
- TextView实现跑马灯效果
- 正则表达式的学习与小结
- 款流行的Markdown编辑器
- Linux常用命令——搜索which,whereis,slocate,find,grep