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