2013-09-27 3 views
0

나는 타원 곡선 공개 키를 생성하기 위해 FlexiEC 공급자를 사용하고 있습니다. 그런 다음 키를 바이트 배열로 변환합니다. 그 후이 바이트 배열에서이 공개 키의 인스턴스를 가져 오려고합니다. 내가 이것을 할 때마다 나는 예외를 얻는다.Flexiprovider 바이트 배열에서 타원 곡선 공개 키

import java.security.KeyPair; 
import java.security.KeyFactory; 
import java.security.KeyPairGenerator; 
import java.security.PrivateKey; 
import java.security.PublicKey; 
import java.security.SecureRandom; 
import java.security.Security; 

import javax.crypto.Cipher; 

import de.flexiprovider.common.ies.IESParameterSpec; 
import de.flexiprovider.core.FlexiCoreProvider; 
import de.flexiprovider.ec.FlexiECProvider; 
import de.flexiprovider.ec.parameters.CurveParams; 
import de.flexiprovider.ec.parameters.CurveRegistry.BrainpoolP160r1; 
import de.flexiprovider.pki.X509EncodedKeySpec; 

[...] 

KeyPairGenerator kpg = KeyPairGenerator.getInstance("ECIES", "FlexiEC"); 
CurveParams ecParams = new BrainpoolP160r1(); 
kpg.initialize(ecParams, new SecureRandom()); 
KeyPair keyPair = kpg.generateKeyPair(); 

byte[] pubKey = keyPair.getPublic().getEncoded(); 

X509EncodedKeySpec pubKeySpec = new X509EncodedKeySpec(pubKey); 
KeyFactory keyFactory = KeyFactory.getInstance("ECIES", "FlexiEC"); 
PublicKey pk = keyFactory.generatePublic(pubKeySpec); 

예외는 다음과 같습니다 :

Exception in thread "main" de.flexiprovider.api.exceptions.InvalidKeySpecException: java.lang.RuntimeException: java.security.InvalidAlgorithmParameterException: Caught IOException("Unknown named curve: 1.3.36.3.3.2.8.1.1.1") 
at de.flexiprovider.ec.keys.ECKeyFactory.generatePublic(ECKeyFactory.java:205) 
at de.flexiprovider.api.keys.KeyFactory.engineGeneratePublic(KeyFactory.java:39) 
at java.security.KeyFactory.generatePublic(KeyFactory.java:328) 
at com.test.App.test(App.java:68) 
at com.test.App.main(App.java:76) 

어떻게 바이트 배열에서 정확하게 키를 복구 할 수 있습니다 다음과 같이

코드는 무엇입니까?

답변

0

나는 "ECIES", "FlexiEC"코드가있어 참조 할 수 있습니다. 이 도움이된다면, 신용이 이행을 완료하는 날 활성화 나를 위해 질문에 대답하는 사람들 owlstead 간다

BadPaddingException: invalid ciphertext

: 여기 링크입니다.

관련 문제