【发布时间】:2018-04-03 06:30:22
【问题描述】:
我正在尝试将存储在SharedPreferences 中的字符串转换为PrivateKey,但我无法这样做。
这就是我将PrivateKey 转换为String 的方式,
kpg = KeyPairGenerator.getInstance("RSA");
kpg.initialize(1024);
kp = kpg.genKeyPair();
publicKey = kp.getPublic();
privateKey = kp.getPrivate();
byte[] privateKeyBytes = publicKey.getEncoded();
String privKeyStr = new String(Base64.encode(privateKeyBytes));
SharedPreferences.Editor editor = getPrefs(context).edit();
editor.putString(user + "_private_key", privKeyStr + "");
editor.commit();
这就是我尝试从SharedPreference 检索密钥并将其转换回PrivateKey 的方式
String privKeyStr = getPrefs(context).getString(user + "_private_key", "no private key");
Log.d("key", privKeyStr);
byte[] sigBytes = new byte[0];
try {
sigBytes = Base64.decode(privKeyStr.getBytes("UTF-8"));
} catch (UnsupportedEncodingException e) {
e.printStackTrace();
}
PKCS8EncodedKeySpec privateKeySpec = new PKCS8EncodedKeySpec(sigBytes);
KeyFactory keyFact = KeyFactory.getInstance("RSA");
PrivateKey privateKey = null;
try {
privateKey = keyFact.generatePrivate(privateKeySpec); //throws exception
} catch (InvalidKeySpecException e) {
e.printStackTrace();
}
这是我不断收到的错误,
java.security.spec.InvalidKeySpecException: java.lang.RuntimeException: error:0c0000b9:ASN.1 encoding routines:OPENSSL_internal:WRONG_TAG
我知道之前已经提出过类似的问题,但似乎都没有解决我的问题。
请帮助我知道我哪里出错了。
【问题讨论】:
-
stackoverflow.com/questions/28218636/… 请检查一下,希望对您有所帮助
-
能否给个解释或示范一下?会更容易理解。
-
而不是
Base64.decode(privKeyStr.getBytes("UTF-8"))使用Base64.decode(privKeyStr,Base64.DEFAULT)在editing之后你还commit/apply吗?
标签: java android cryptography rsa