privaten Schlüsselgenerierung zu erzeugenAusgabe in privaten Schlüssel
public PrivateKey getStoredPrivateKey(String filePath) {
PrivateKey privateKey = null;
byte[] keydata = getKeyData(filePath);
PKCS8EncodedKeySpec encodedPrivateKey = new PKCS8EncodedKeySpec(keydata);
KeyFactory keyFactory = null;
try {
keyFactory = KeyFactory.getInstance("RSA");
} catch (NoSuchAlgorithmException e) {
e.printStackTrace();
}
try {
System.out.println("hello");
privateKey = keyFactory.generatePrivate(encodedPrivateKey);
} catch (InvalidKeySpecException e) {
e.printStackTrace();
}
return privateKey;
}
ich bin mit hier
PrivateKey privateKey = new KryptoUtil().getStoredPrivateKey(privateKeyFilePath);
aber seine zeigt Fehler
hello
java.security.spec.InvalidKeySpecException:
java.security.InvalidKeyException: IOException : version mismatch: (supported: 00, parsed: 03
at sun.security.rsa.RSAKeyFactory.engineGeneratePrivate(Unknown Source)
ich vorbei eine (P12-Datei) in der Funktion getStoredPrivateKey (String filePath).
warum gibt es Fehler?
Sind Sie sicher, dass Ihr privater Schlüssel der Spezifikation PKCS # 8 ist. Versuchen Sie es mit anderen Spezifikationen wie RSAPrivateKeySpec –
Wie kann ich feststellen, dass es nicht PKCS # 8 ist – Mudit