Sto utilizzando nella mia app crittografia RSA. Per memorizzare la chiave pubblica generata, la converto in stringa e la salvo nel database.Chiave da String in Java RSA
Key publicKey=null;
Key privateKey=null;
KeyPair keyPair=RsaCrypto.getKeyPairRSA(1024);
publicKey=keyPair.getPublic();
privateKey=keyPair.getPrivate();
String publicK=Base64.encodeToString(publicKey.getEncoded(), Base64.DEFAULT);
String privateK=Base64.encodeToString(privateKey.getEncoded(), Base64.DEFAULT);
ho salvare le stringhe publicK
e privateK
. Il mio problema è che quando voglio crittografare/decifrare il testo con RSA e usare la mia chiave salvata in formato stringa non so come convertirlo in Key
.
public static String encrypt(Key publicKey, String inputText){
byte[]encodedBytes=null;
String encryptedText="";
try {
Cipher cipher=Cipher.getInstance("RSA");
cipher.init(Cipher.ENCRYPT_MODE, publicKey);
encodedBytes=cipher.doFinal(inputText.getBytes());
} catch (Exception e) {Log.e("Error", "RSA encryption error"); }
encryptedText=Base64.encodeToString(encodedBytes, Base64.DEFAULT);
return encryptedText;
}
Avete qualche idea? Grazie mille
favore, per favore, per favore non memorizzare le chiavi private non crittografate nel tuo database. Se devi archiviare chiavi private conosciute come escrowing e dovresti crittografarle con una chiave simmetrica nota solo alla tua applicazione. – KyleM
Grazie, sì ci sto pensando. Potrebbe darmi un consiglio, qual è il modo migliore per memorizzare una chiave in app? Grazie – rgreso
utilizzare un keystore Java protetto da password. Cerca il keytool Java ... – KyleM