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