RSA-Verschlüsselung in Android

Ich schreibe ein Programm, das RSA in Android verwendet. Ich habe folgendes Problem: Ich erhalte die RSA-Schlüssel:

KeyPair kp = kpg.genKeyPair();
publicKey = kp.getPublic();
privateKey = kp.getPrivate();

Verwenden der Verschlüsselungsfunktion zum Verschlüsseln einer Testzeichenfolge:

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);

In der Entschlüsselungsfunktion entschlüssele ich die Daten zurück, um die ursprüngliche Zeichenfolge zu erhalten

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);

Die im Protokoll ausgedruckten Daten in 'p' stimmen nicht mit der ursprünglichen Zeichenfolge "test" überein. Wo gehe ich da falsch?

Antworten auf die Frage(1)

Ihre Antwort auf die Frage