项目合作需要,和其他网站通信,消息内容采用RSA加密方式传递。之前没有接触过RSA,于是两个问题出现了:
声明: 环境WIN 7 + python 2.6.6 RSA格式:PEM
一、Python下RSA加密解密怎么做? 现在网上搜索关于RSA的信息,然后看一下Python下是怎么做的。
找到两种方法:
1、使用rsa库 安装
pip install rsa
可以生成RSA公钥和密钥,也可以load一个.pem文件进来。
按 Ctrl+C 复制代码
按 Ctrl+C 复制代码
2、使用M2Crypto python关于RSA的库还是蛮多的,当然也可以直接用openSSL。M2Crypto安装的时候比较麻烦,虽然官网有exe的安装文件,但是2.6的有bug,建议使用0.19.1版本,最新的0.21.1有问题。
1 # -*- coding: utf-8 -*- 2 __author__ = 'luchanghong' 3 from M2Crypto import RSA,BIO 4 5 rsa = RSA.gen_key(1024, 3, lambda *agr:None) 6 pub_bio = BIO.MemoryBuffer() 7 priv_bio = BIO.MemoryBuffer() 8 9 rsa.save_pub_key_bio(pub_bio) 10 rsa.save_key_bio(priv_bio, None) 11 12 pub_key = RSA.load_pub_key_bio(pub_bio) 13 priv_key = RSA.load_key_bio(priv_bio) 14 15 message = 'i am luchanghong' 16 17 encrypted = pub_key.public_encrypt(message, RSA.pkcs1_padding) 18 decrypted = priv_key.private_decrypt(encrypted, RSA.pkcs1_padding) 19 20 print decrypted
用法差不多一致。load密钥的方式也有好几种。 二、跨平台密钥不统一 RSA加密验证搞定了,但是和java平台交互的时候出问题,java生成的密钥用Python根本load不了,更别说加密了,反之Java也load不了Python生成的密钥。 上网查找原因,RSA认真流程肯定没有问题,关键是不同平台执行RSA的标准有些偏差。
相关推荐
文档中提供了python3实现RSA公钥加密、私钥解密、私钥加密、公钥解密、私钥签名、公钥验签,整套源代码及公钥私钥文件,亲测可用
python Django RSA 前台加密 后端解密,简单demo。
python实现的RSA加密解密算法,带图形界面,key.py随机生成公钥私钥,消息可利用加密器解密器进行加密
C#做的RSA加密解密, 带winform界面, 测试通过, 代码完整。
由于Java的RSA加解密一般都是用RSA/ECB/PKCS1PADDING,导致Python一般的RSA加密库的加解密结果与Java的不兼容,Python下目前能与之兼容的RSA的库目前发现的只有一个,就是m2crypto。 这个库目前的问题是在windows...
RSA加密解密C#实现调用实例 public string RSAEncrypt(string xmlPublicKey, string m_strEncryptString) { try { byte[] PlainTextBArray; byte[] CypherTextBArray; string Result; System.Security....
主要介绍了Python3加密解密库Crypto的RSA加解密和签名/验签实现方法实例,需要的朋友可以参考下
RSA加密解密算法 C++ 密码学 RSA加密解密算法 C++ 密码学 RSA加密解密算法 C++ 密码学
unity工具类RSA加密和解密
易语言调用JSEncrypt实现RSA加密解密。Tags:JSEncryptRSA加密解密。
RSA加密解密工具,用于各类敏感信息文件的加密和解密,压缩包内含操作说明
RSA加密解密算法源码,功能齐全,没有密码,使用方便,学习用.
基于Python的RSA加密算法及其几种破解方法的研究.pdf
这个算法非原创,真心不错,所以上传分享出来.实测过,满足需求
Android RSA加密解密demo,详情请参看博客:http://blog.csdn.net/bbld_/article/details/38777491
采用OpenSSL进行RSA加密解密,对Delphi-OpenSSL进行重构。 1、支持公钥加密、解密,私钥加密解密。 2、支持PKCS1和PKCS8两种密钥格式。 3、支持PKCS#1 v1.5、PKCS#1 OAEP、SSL v2等填充方式。 4、支持生成密钥对。 5...
前端RSA加密解密的使用,含jsencrypt.js文件(uni-app也可用)
RSA加密解密算法,相当不错的例子,适合初学者参考
经过本人修改,简化并完善了别人的代码,使其更加的容易理解和学习! 此为一个完整的项目,...功能:服务端随机生成密钥,JS用公钥加密,服务端用私钥解密。用到的JS加密文件是从官网下载的最新版,速度快,稳定性好!
RSA解密加密JAVA