您的位置:首页 > 编程语言 > C语言/C++

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

2018-01-30 11:28 375 查看

生成私钥

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 rsa openssl