Как зашифровать и расшифровать с помощью Camellia 128bit в коде Android JAVA?
Каков синтаксис имени провайдера для Camellia 128bit в коде Android JAVA?? я пытаюсь изменить с
Cipher.getInstance("AES/CBC/PKCS7Padding")
в
Cipher.getInstance("Camellia/CBC/PKCS7Padding","BC")
но он говорит, что поставщик BC не предоставляет "Camellia/CBC/PKCS7Padding". Ниже мой код
try {
String keyString = "Potatoman55@";//length of key is 16
Cipher desCipher = Cipher.getInstance("Camellia/CBC/PKCS7Padding","BC");
byte[] key = new byte[0];
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.GINGERBREAD) {
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.KITKAT) {
key = keyString.getBytes(StandardCharsets.UTF_8);
}
}
MessageDigest sha = MessageDigest.getInstance("SHA-1");
key = sha.digest(key);
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.GINGERBREAD) {
key = Arrays.copyOf(key, 16); // use only first 128 bit
}
SecretKeySpec secretKeySpec = new SecretKeySpec(key, "AES");
desCipher.init(Cipher.ENCRYPT_MODE, secretKeySpec);
String plainText = "hello wolrd";
System.out.println("plaintext: "+plainText);
byte[] text = plainText.getBytes("UTF-8");
byte[] textencrypted = desCipher.doFinal(text);
String textEnc = null;
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.O) {
System.out.println("encrypted: " + Base64.getEncoder().encodeToString(textencrypted));
textEnc = Base64.getEncoder().encodeToString(textencrypted);
}
result.success(textEnc);
} catch (Exception ex) {
System.out.println(ex.toString());
}
1 ответ
Решение
Я успешно запустил код по этому коду
new org.bouncycastle.jce.provider.BouncyCastleProvider());
как провайдер. Большое спасибо за этот комментарий. ниже полный синтаксис
Cipher desCipher = Cipher.getInstance("Camellia/CBC/PKCS7Padding",new org.bouncycastle.jce.provider.BouncyCastleProvider());