Piszę program, który wykorzystuje RSA w Androidzie. Mam następujący problem: otrzymuję kluczy RSA:szyfrowania RSA w Androidzie
KeyPair kp = kpg.genKeyPair();
publicKey = kp.getPublic();
privateKey = kp.getPrivate();
Korzystanie z funkcji szyfrowania do szyfrowania ciąg testowy:
String test ="test";
byte[] testbytes = test.getBytes();
Cipher cipher = Cipher.getInstance("RSA");
cipher.init(Cipher.ENCRYPT_MODE, publicKey);
byte[] cipherData = cipher.doFinal(testbytes);
String s = new String(cipherData);
Log.d("testbytes after encryption",s);
w funkcji deszyfrowania jestem odszyfrowywania danych z powrotem dostać oryginalny ciąg
Cipher cipher2 = Cipher.getInstance("RSA");
cipher2.init(Cipher.DECRYPT_MODE, privateKey);
byte[] plainData = cipher.doFinal(cipherData);
String p = new String(plainData);
Log.d("decrypted data is:",p);
dane w „p” wydrukowanym w dzienniku nie pasuje oryginalny napis „test”. Gdzie się mylę?
Cóż, co jest drukowany w dzienniku? Jeśli masz niedopasowane klucze lub zniekształcony szyfr, otrzymasz wyjątek, a nie niepoprawną odpowiedź. –
pamiętać, że 'cipherData' będzie losowy ciąg binarny-jak również, więc przekształcenie go na ciąg używając tylko surowe bajty (' łańcuch s = new String (cipherData); ') może dać dziwne wyniki. –