python java RSA加密算法互通
! python rsa生成是 .pem文件,java中的rsa是一串字符串
python 生成的是pkcs#1 格式的,java好像是pkcs#8的。
python的密钥和公钥是 ' -----BEGIN RSA PUBLIC KEY----- '开头, '-----END RSA PUBLIC KEY-----'结尾 。
我们公司的 java 公钥和密钥是 按照 X.509 标准进行编码的密钥的字节, 经过 X509EncodedKeySpec 如图
python 和 java 互通 RSA加密解密代码如下:
def encrypt(content): ''' # 用公钥加密 :param content: 加密的字符串 :return: ''' # TODO PRIVE_KEY java端给的公钥 key = RSA.importKey(base64.b64decode(PRIVE_KEY)) cipher = PKCS1_v1_5.new(key) return base64.b64encode(cipher.encrypt(str(content).encode(encoding='utf-8'))).decode('utf-8') def decrypt(crypt): ''' # 用公钥加密 :param crypt: 加密的字符串 :return: ''' # TODO PRIVE_KEY java端给的私钥 rsakey = RSA.importKey(base64.b64decode(PRIVE_KEY)) cipher = PKCS1_v1_5.new(rsakey) return cipher.decrypt(base64.b64decode(crypt), random_generator).decode('utf-8')
在python中私钥和公钥千万别传错,否则会报 ’不支持格式的错误‘