给定Java ssh-rsa PublicKey,如何构建SSH2公钥?

时间:2010-08-27 21:07:59

标签: java public-key ssh-keys

我正在使用publicKey.getEncoded(),然后在前面添加“ssh-rsa”,然后对其进行base64编码。然后我添加SSH2页眉/页脚。但它不会解码...

1 个答案:

答案 0 :(得分:16)

Java公钥被编码为标准的X.509 SubjectPublicKeyInfo结构。

SSH2使用自己的简单格式。 Base-64编码下面显示的encode方法的结果,并附加必要的SSH2页眉和页脚。

public static byte[] encode(RSAPublicKey key)
  throws IOException
{
  ByteArrayOutputStream buf = new ByteArrayOutputStream();
  byte[] name = "ssh-rsa".getBytes("US-ASCII");
  write(name, buf);
  write(key.getPublicExponent().toByteArray(), buf);
  write(key.getModulus().toByteArray(), buf);
  return buf.toByteArray();
}

private static void write(byte[] str, OutputStream os)
  throws IOException
{
  for (int shift = 24; shift >= 0; shift -= 8)
    os.write((str.length >>> shift) & 0xFF);
  os.write(str);
}

请参阅this answer以转换其他方向,从OpenSSH转换为Java。