首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >McEliece (FlexiProvider):如何从字节数组创建KeyPair?

McEliece (FlexiProvider):如何从字节数组创建KeyPair?
EN

Stack Overflow用户
提问于 2013-12-13 23:17:05
回答 1查看 710关注 0票数 1

我使用Flexi提供程序(用于McEliece算法)生成我的公钥和私钥,然后我将其保存到文件中,现在我需要从文件中加载键盘,我可以读取文件并获得公钥字节数组和私钥字节数组,但我不知道如何从它创建keypair :我使用flexiprovider.de for McEliece算法:

用于生成McEliece键:

代码语言:javascript
复制
import de.flexiprovider.api.keys.KeySpec;
import de.flexiprovider.core.FlexiCoreProvider;
import de.flexiprovider.pqc.FlexiPQCProvider;
import de.flexiprovider.pqc.ecc.mceliece.McElieceKeyFactory;
import de.flexiprovider.pqc.ecc.mceliece.McElieceKeyPairGenerator;

public KeyPair generateKeyPair(){
    KeyPair kp = null;
    int KeySize = 256;
    Security.addProvider(new FlexiCoreProvider());
    Security.addProvider(new FlexiPQCProvider());

    try
    {

        McElieceKeyPairGenerator mcElieceKeyPairGenerator = new McElieceKeyPairGenerator();
        mcElieceKeyPairGenerator.initialize(KeySize, new SecureRandom());
        kp = mcElieceKeyPairGenerator.generateKeyPair();
    } catch (Exception e) {
        System.out.println(e.ToString());
    }
    return kp;
}

用于从Byte加载KeyPair:

代码语言:javascript
复制
public KeyPair readKeyPair(byte[] privateKey, byte[] publicKey){
       //?? How can i create KeyPair
}

我试着使用McElieceKeyFactory,但我不知道如何使用它,它需要KeySpec (de.flexiprovider.api.keys.KeySpec)来生成私钥和公钥,但是de.flexiprovider.api.keys.KeySpec是抽象类,不能用它创建新实例。那我该怎么办?

编辑1:保存方法:

代码语言:javascript
复制
public void writeFile(byte[] data, String fileName) throws IOException{
    FileOutputStream out = new FileOutputStream(fileName);
    out.write(data);
    out.close();
}

public void saveKeyPair(KeyPair keyPair){
    byte[] privateKeyBytes = keyPair.getPrivate().getEncoded();
    byte[] publicKeyBytes = keyPair.getPublic().getEncoded();

    writeFile(privateKeyBytes,"Private.key");
    writeFile(publicKeyBytes,"Public.key");
}
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2013-12-14 00:08:05

请尝试以下代码。还请注意,我没有直接使用密钥对生成器和密钥工厂实现。

代码语言:javascript
复制
KeyPairGenerator mcElieceKeyPairGenerator = KeyPairGenerator.getInstance("McEliece");
mcElieceKeyPairGenerator.initialize(keysize, new SecureRandom());
kp = mcElieceKeyPairGenerator.generateKeyPair();

final byte[] publicKeyData = kp.getPublic().getEncoded(); 
X509EncodedKeySpec publicKeySpec = new X509EncodedKeySpec(publicKeyData);
KeyFactory mcElieceKeyFactory = KeyFactory.getInstance("McEliece");
PublicKey regeneratedPublicKey = mcElieceKeyFactory.generatePublic(publicKeySpec);

final byte[] privateKeyData = kp.getPrivate().getEncoded();
PKCS8EncodedKeySpec privateKeySpec = new PKCS8EncodedKeySpec(privateKeyData);
PrivateKey regeneratedPrivateKey = mcElieceKeyFactory.generatePrivate(privateKeySpec);
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/20577622

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档