Używam w mojej aplikacji kryptografii RSA. Aby przechowywać wygenerowany klucz publiczny, konwertuję go na String, a następnie zapisz go w bazie danych.Klucz z łańcucha znaków w języku 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);
zapisać Struny publicK
i privateK
. Mój problem polega na tym, że gdy chcę zaszyfrować/odszyfrować tekst za pomocą RSA i użyć zapisanego klucza w formacie String, nie wiem jak przekonwertować go na 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;
}
Masz jakiś pomysł? Thanks a lot
Proszę, proszę, proszę nie przechowywać niezaszyfrowanych kluczy prywatnych w bazie danych. Jeśli musisz przechowywać klucze prywatne, które nazywają się escrowing, powinieneś szyfrować je kluczem symetrycznym znanym tylko twojej aplikacji. – KyleM
Dziękuję, tak, myślę o tym. Czy możesz mi doradzić, jaki jest najlepszy sposób przechowywania klucza w aplikacji? Dzięki – rgreso
użyj chronionego hasłem pliku kluczy Java. Sprawdź keytool Java ... – KyleM