我试图使用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");
}
}