使用OpenSSL生成RSA密钥对供Java和C++使用

生成私钥

openssl genrsa -out rsa_private_key.pem 1024

Java使用的私钥

Java使用的时候需要再次编码,转换成pkcs8编码,使用如下命令:

 openssl pkcs8 -topk8 -in rsa_private_key.pem -out pkcs8_rsa_private_key.pem -nocrypt

由私钥生成公钥

openssl rsa -in rsa_private_key.pem -out rsa_public_key.pem -pubout

客户端加密使用公钥rsa_public_key.pem 来加密, Java服务端使用pkcs8_rsa_private_key.pem 来解密

Java使用未转码的私钥可用如下代码(未测试)参考来源:Java中使用OpenSSL生成的RSA公私钥进行数据加解密

RSAPrivateKeyStructure asn1PrivKey = new RSAPrivateKeyStructure((ASN1Sequence) ASN1Sequence.fromByteArray(priKeyData));  
RSAPrivateKeySpec rsaPrivKeySpec = new RSAPrivateKeySpec(asn1PrivKey.getModulus(), asn1PrivKey.getPrivateExponent());  
KeyFactory keyFactory= KeyFactory.getInstance("RSA");  
PrivateKey priKey= keyFactory.generatePrivate(rsaPrivKeySpec);  

你可能感兴趣的:(杂谈,java)