Я могу сгенерировать пару ключей и шифрование и дешифрование с помощью 4 символов строки для приведенного ниже оператора.
byte[] input = "userid".getBytes();
Но когда я увеличиваю длину строки, как показано ниже, я получаю исключение
byte[] input = "userid:789".getBytes();
Код:
import java.security.Key;
import java.security.KeyPair;
import java.security.KeyPairGenerator;
import java.security.SecureRandom;
import java.security.Security;
import javax.crypto.Cipher;
public class RSAOAEP {
public static void main(String[] args) throws Exception {
Security.addProvider(new org.bouncycastle.jce.provider.BouncyCastleProvider());
byte[] input = "userid:789".getBytes();
Cipher cipher = Cipher.getInstance("RSA/None/OAEPWithSHA1AndMGF1Padding", "BC");
SecureRandom random = new SecureRandom();
KeyPairGenerator generator = KeyPairGenerator.getInstance("RSA", "BC");
generator.initialize(386, random);
KeyPair pair = generator.generateKeyPair();
Key pubKey = pair.getPublic();
Key privKey = pair.getPrivate();
System.out.println("privateKey: "+privKey);
System.out.println("publicKey: "+pubKey);
cipher.init(Cipher.ENCRYPT_MODE, pubKey, random);
byte[] cipherText = cipher.doFinal(input);
System.out.println("cipher: " + new String(cipherText));
cipher.init(Cipher.DECRYPT_MODE, privKey);
byte[] plainText = cipher.doFinal(cipherText);
System.out.println("plain : " + new String(plainText));
}
}
Исключение:
Исключение в потоке «основной» java.lang.ArrayIndexOutOfBoundsException: слишком много данных для блока RSA в org.bouncycastle.jcajce.provider.asymmetric.rsa.CipherSpi.engineDoFinal(неизвестный источник) в javax.crypto.Cipher.doFinal(Cipher.java :2165) на RSAOAEP.main(RSAOAEP.java:29)