0

我用我的代码生成了 ed25519 密钥对,但是当我将公钥文件和私钥文件复制到 linux 机器时。看起来我的密钥对文件有问题。 linux机器无法使用密钥对文件登录

这是我的代码:

public static void main(String[] args) throws Exception {
    createED25519();
}

private static void createED25519() throws IOException {
    KeyPairGeneratorSpi.Ed25519 ed25519 = new KeyPairGeneratorSpi.Ed25519();
    ed25519.initialize(256, new SecureRandom());
    KeyPair keyPair = ed25519.generateKeyPair();
    PublicKey publicKey = keyPair.getPublic();
    PrivateKey privateKey = keyPair.getPrivate();

    writeEd25519PrivateKey(privateKey);
    writeEd25519PublicKey(publicKey);
}

private static void writeEd25519PrivateKey(PrivateKey privateKey) throws IOException {
    try (PemWriter w = new PemWriter(new FileWriter("D:\\keypair\\Ed25519\\java.pem"))) {
        Ed25519PrivateKeyParameters ed25519PrivateKeyParameters = (Ed25519PrivateKeyParameters) PrivateKeyFactory
                .createKey(privateKey.getEncoded());
        byte[] content = OpenSSHPrivateKeyUtil.encodePrivateKey(ed25519PrivateKeyParameters);
        PemObject o = new PemObject("OPENSSH PRIVATE KEY", content);
        w.writeObject(o);
    }
}

private static void writeEd25519PublicKey(PublicKey publicKey) throws IOException {
    try (FileWriter fileWriter = new FileWriter("D:\\keypair\\Ed25519\\java.pub")) {
        Ed25519PublicKeyParameters publicKeyParameters = (Ed25519PublicKeyParameters) PublicKeyFactory
                .createKey(publicKey.getEncoded());
        String publicKeyPub = "ssh-ed25516 " + Base64.getEncoder().encodeToString(OpenSSHPublicKeyUtil.encodePublicKey(publicKeyParameters));
        fileWriter.write(publicKeyPub);
    }

}

pom.xml:

  <dependency>
        <groupId>org.bouncycastle</groupId>
        <artifactId>bcpkix-jdk15on</artifactId>
        <version>1.67</version>
    </dependency>

生成的公钥内容为:

ssh-ed25516 AAAAC3NzaC1lZDI1NTE5AAAAIJC+iPZZ56a7wogB/UxlmSbrN2hjaOnu26b2pVX6zkZr

生成的私钥内容为:

-----BEGIN OPENSSH PRIVATE KEY-----
b3BlbnNzaC1rZXktdjEAAAAABG5vbmUAAAAEbm9uZQAAAAAAAAABAAAAMwAAAAtz
c2gtZWQyNTUxOQAAACCQvoj2Weemu8KIAf1MZZkm6zdoY2jp7tum9qVV+s5GawAA
AIhAEzACQBMwAgAAAAtzc2gtZWQyNTUxOQAAACCQvoj2Weemu8KIAf1MZZkm6zdo
Y2jp7tum9qVV+s5GawAAAED5xx3tLFBLSXC/SE1dSKL3vuUs9mj2+3/086sbXePu
TJC+iPZZ56a7wogB/UxlmSbrN2hjaOnu26b2pVX6zkZrAAAAAAECAwQF
-----END OPENSSH PRIVATE KEY-----

希望有人能告诉代码有什么问题,或者有没有其他方法可以生成用于SSH登录的ED25519密钥对文件,谢谢!

4

0 回答 0