У меня есть только закрытый ключ, и мне нужно рассчитать открытый ключ из него в java. После этого ответа Get public key from private in Java я придумал следующий код:Неверный открытый ключ из частного ключа в java
String pemString = "full private key string here";
pemString = pemString.replace("-----BEGIN RSA PRIVATE KEY-----\n", "");
pemString = pemString.replace("-----END RSA PRIVATE KEY-----", "");
pemString = pemString.replace("\n", ""); //without this exception: Illegal base64 character a
logger.info(pemString);
byte[] decoded = Base64.getDecoder().decode(pemString);
KeyFactory kf = KeyFactory.getInstance("RSA");
PKCS8EncodedKeySpec keySpec = new PKCS8EncodedKeySpec(decoded);
PrivateKey privatekey = kf.generatePrivate(keySpec);
RSAPrivateCrtKey privk = (RSAPrivateCrtKey)privatekey;
RSAPublicKeySpec publicKeySpec = new RSAPublicKeySpec(privk.getModulus(), privk.getPublicExponent());
PublicKey pubKey = kf.generatePublic(publicKeySpec);
String pubString = Base64.getEncoder().encodeToString(pubKey.getEncoded());
logger.info(pubString);
Но если сравнить вывод кода с открытым ключом, EC2 магазины в .ssh/авторизованных ключей это не то же самое. Что я делаю не так?
Я хочу добиться ssh-keygen -y
Принимая ваш ответ, потому что он указал на фактическую проблему. Удалось сделать это прямо в java с преобразованием формата http://stackoverflow.com/questions/3706177/how-to-generate-ssh-compatible-id-rsa-pub-from-java – cen