2016-12-24 71 views
2

我将Key(security)转换为字符串并将其转换为该对象时出现问题。我有一些错误:将字符串转换为键,反之亦然

java.lang.IllegalArgumentException: Illegal base64 character 20

和我的代码:

KeyPairGenerator kpairg = KeyPairGenerator.getInstance("RSA"); 
kpairg.initialize(1024); 
KeyPair kpair = kpairg.genKeyPair(); 
Key publicKey = kpair.getPublic(); 

// to String 
String textFromKey = Base64.getEncoder().encodeToString(publicKey.getEncoded()); 

// to Key 
byte[] byteKey = Base64.getDecoder().decode(textFromKey.getBytes()); 
X509EncodedKeySpec X509publicKey = new X509EncodedKeySpec(byteKey); 
KeyFactory kf = KeyFactory.getInstance("RSA"); 
Key pubb = kf.generatePublic(X509publicKey); 

textFromKey is sending to UDP server textFromKey is a output from server if I want to use that key 我看到在该网站的一些答案,但任何事情帮助我。你能看看这个吗?

IDE告诉我,有一个问题: byte[] byteKey = Base64.getDecoder().decode(textFromKey.getBytes());

+1

非法字符是20(十六进制)即空格。如果你打印例如'“AAA =”'和“”AAA =“'他们看起来相同,但是不同,后者在4648中是不合法的。检查你正在解码的字符串是否完全相同。或者如果你想添加空间,可以使用'getMimeDecoder()'; MIME允许流浪的非base64字符。 –

回答

-1

的问题不是只从代码清晰。你可以试试只是

X509EncodedKeySpec X509publicKey = new X509EncodedKeySpec(publicKey.getEncoded()); 

和回来?

相关问题