génération de la clé privéeProblème pour générer la clé privée
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;
}
Je l'utilise ici
PrivateKey privateKey = new KryptoUtil().getStoredPrivateKey(privateKeyFilePath);
mais son erreur montrant
hello
java.security.spec.InvalidKeySpecException:
java.security.InvalidKeyException: IOException : version mismatch: (supported: 00, parsed: 03
at sun.security.rsa.RSAKeyFactory.engineGeneratePrivate(Unknown Source)
Je passe un (.p12) dans la fonction getStoredPrivateKey (String filePath).
pourquoi son erreur donnant?
Etes-vous sûr que votre clé privée est de spécification PKCS # 8. Essayez avec d'autres spécifications comme RSAPrivateKeySpec –
comment puis-je identifier que ce n'est pas PKCS # 8 – Mudit