我正在使用RSA算法生成公钥和私钥
final KeyPairGenerator keyGen = KeyPairGenerator.getInstance(ALGORITHM);
keyGen.initialize(1024);
final KeyPair key = keyGen.generateKeyPair();
final PrivateKey privateKey=key.getPrivate();
final PublicKey publickey=key.getPublic();
之后,这些 key 将使用Base64编码器进行编码,并将其保存到数据库中。
如何在Java中将此编码的字符串转换为私钥和公钥类型是为了解密文件。
使用Base64Decoder解码此String时,将获得一个字节数组。如何将此字节数组转换为公钥或私钥类型?
最佳答案
如果您有一个byte []代表键上getEncoded()的输出,则可以使用KeyFactory将其转换回PublicKey对象或PrivateKey对象。
byte[] privateKeyBytes;
byte[] publicKeyBytes;
KeyFactory kf = KeyFactory.getInstance("RSA"); // or "EC" or whatever
PrivateKey privateKey = kf.generatePrivate(new PKCS8EncodedKeySpec(privateKeyBytes));
PublicKey publicKey = kf.generatePublic(new X509EncodedKeySpec(publicKeyBytes));
关于java - 如何将字节数组转换为PrivateKey或PublicKey类型?,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/19353748/