我试图使用EdDSA算法来使用jar eddsa 0.3.0生成密钥。但是,当我尝试执行java.security.NoSuchAlgorithmException: Ed25519 KeyPairGenerator not available时得到KeyPairGenerator.getInstance("Ed25519");

另外,当我尝试生成签名时,出现以下异常java.security.NoSuchAlgorithmException: Ed25519 Signature not available
有任何使它起作用的示例吗?

我已经完成了研究,但是我是加密阶段的新手,我真的不知道如何使它工作。

我知道eddsaparam构造函数是错误的。下面的代码:

KeyPairGenerator keyPairGenerator=KeyPairGenerator.getInstance("EdDSA");//getInstance("ECDSA","BC");//EDDSA
            SecureRandom secureRandom=SecureRandom.getInstance("SHA1PRNG");

            EdDSANamedCurveSpec ed25519 = EdDSANamedCurveTable.getByName("Ed25519");

            EdDSAParameterSpec edDSAParameterSpec = new EdDSAParameterSpec(ed25519, "Ed25519");

            keyPairGenerator.initialize(edDSAParameterSpec,secureRandom);

最佳答案

恐怕“ Ed25519”是一个错字,应该是“ EcDSA”。
假设您的pom文件包含以下内容:

<dependency>
    <groupId>net.i2p.crypto</groupId>
    <artifactId>eddsa</artifactId>
    <version>0.3.0</version>
</dependency>

您的代码类似于:
import net.i2p.crypto.eddsa.EdDSASecurityProvider;

import java.security.KeyPairGenerator;
import java.security.NoSuchAlgorithmException;
import java.security.NoSuchProviderException;
import java.security.Security;

public class App {
    public static void main(String[] args) throws NoSuchAlgorithmException, NoSuchProviderException {
        // throws NoSuchAlgorithmException: EdDSA KeyPairGenerator not available
        //KeyPairGenerator.getInstance("EdDSA");

        // add eddsa to the security providers
        Security.addProvider(new EdDSASecurityProvider());

        // throws: NoSuchAlgorithmException: Ed25519 KeyPairGenerator not available
        //KeyPairGenerator.getInstance("Ed25519");

        // throws: NoSuchAlgorithmException: no such algorithm: Ed25519 for provider EdDSA
        //KeyPairGenerator.getInstance("Ed25519", "EdDSA");

        // works
        KeyPairGenerator.getInstance("EdDSA", "EdDSA");

        // also works
        KeyPairGenerator.getInstance("EdDSA");
    }
}

09-12 19:37